正确生成1–100随机整数应为rand.nextInt(100) + 1;读取整数需用hasNextInt()预检并配合next()清空非法输入;主循环用while(true)配合break实现,每次比较输出高/低/正确提示并计数。

Java 控制台猜数字游戏的核心是用 Scanner 读取用户输入,配合 Random 生成目标数,并通过循环和条件判断实现交互逻辑。它不依赖 GUI 或外部库,适合初学流程控制与输入处理。
如何用 Random 生成 1–100 的随机整数
别直接写 new Random().nextInt(100)——这会生成 0–99 的数,不符合“1 到 100”的常见需求。
正确做法是偏移起始值:
Random rand = new Random(); int target = rand.nextInt(100) + 1; // 生成 1 ~ 100(含)
注意:nextInt(n) 返回的是 [0, n) 区间,加 1 才能对齐自然数范围。如果要支持自定义范围(如 1–50),可封装为 rand.nextInt(max - min + 1) + min。
立即学习“Java免费学习笔记(深入)”;
怎么用 Scanner 安全读取整数并避免崩溃
用户输字母或空行时,scanner.nextInt() 会抛出 InputMismatchException,程序直接终止。必须捕获并清空错误输入缓冲区。
推荐结构:
- 用
hasNextInt()预检输入类型 - 若非整数,调用
next()消费非法 token,避免死循环 - 始终在循环内重置提示,防止卡住
示例片段:
Scanner scanner = new Scanner(System.in);
while (!scanner.hasNextInt()) {
System.out.print("请输入一个有效的整数:");
scanner.next(); // 跳过非法输入
}
int guess = scanner.nextInt();怎么设计主循环并反馈猜测结果(高/低/正确)
核心逻辑是 while (guess != target),每次比较后给出明确提示,且记录尝试次数。
关键细节:
- 不要在循环外读第一次输入——会导致少一次提示机会
- 用
System.out.println()而非print()给出反馈,保证换行清晰 - 当猜中时,跳出循环并输出总次数,不要继续询问
典型结构:
int attempts = 0;
while (true) {
System.out.print("请输入你的猜测(1-100):");
if (scanner.hasNextInt()) {
int guess = scanner.nextInt();
attempts++;
if (guess == target) {
System.out.println("恭喜!你猜中了!共用了 " + attempts + " 次。");
break;
} else if (guess < target) {
System.out.println("太小了!");
} else {
System.out.println("太大了!");
}
} else {
System.out.println("请输入一个整数!");
scanner.next();
}
}容易被忽略的边界问题:输入重复、资源未关闭、无退出机制
控制台程序虽小,但真实场景下这些点常导致体验断裂或资源泄漏:
-
Scanner对象建议在结束前调用scanner.close(),尤其在多次运行或嵌入其他模块时 - 没考虑用户连续输错、反复试探同一数字——这不是 bug,但可加一句“你已经试过这个数了”提升体验(需用
Set记录) - 缺少“输入 q 退出”这类柔性退出方式,纯靠猜中结束不够友好;可在
hasNextInt()失败后检查是否为"q"或"quit"
比如扩展退出逻辑:
if (scanner.hasNext("q|quit")) {
System.out.println("游戏已退出。答案是:" + target);
break;
}真正让这个小游戏“能用”和“好用”的分水岭,不在算法,而在对 Scanner 缓冲区行为的理解、对异常输入路径的覆盖,以及是否把用户当成会乱按键盘的真实人类来看待。










