Scanner读取输入时nextLine()跳过是因为nextInt()等不消费换行符,需统一用nextLine()再转类型或调用scanner.nextLine()清缓存;温度转换日常用double,高精度用BigDecimal;长度单位转换推荐以米为基准的系数映射表;InputMismatchException应通过hasNextDouble()预检并跳过非法输入。

用 Scanner 读取用户输入时为什么总卡住或跳过输入?
常见现象是:第一次输入数字后,紧接着的 nextLine() 直接返回空字符串。这是因为 nextInt()、nextDouble() 等方法不消费换行符(\n),而后续的 nextLine() 立刻读到这个残留换行符,就“以为”用户按了回车没输内容。
- 统一用
nextLine()读所有输入,再手动转类型:String input = scanner.nextLine(); double value = Double.parseDouble(input);
- 如果必须混用,每次调用
nextInt()后加一句scanner.nextLine();清掉换行符 - 避免在同一个
Scanner实例中频繁切换nextXxx()和nextLine()
温度单位转换(摄氏/华氏/开尔文)该用 double 还是 BigDecimal?
日常工具类转换对精度要求不高,double 足够且性能好;但若涉及金融级温度校准或需控制舍入行为(比如强制“四舍五入到小数点后1位”),就得上 BigDecimal。
- 摄氏转华氏公式:
°F = °C × 9/5 + 32—— 用double计算即可 - 若要保留 1 位小数输出:
String.format("%.1f", result)比Math.round()更直观 -
BigDecimal示例仅在需要精确控制时才写:BigDecimal c = new BigDecimal("25.5"); BigDecimal f = c.multiply(new BigDecimal("9")).divide(new BigDecimal("5")).add(new BigDecimal("32"));
长度单位转换表怎么设计才容易扩展?
硬编码 if-else 或 switch 处理厘米→米、英寸→厘米……很快会失控。推荐用「基准单位」+「换算系数」方式,把所有单位映射到米(m):
- 定义
Map存系数:coefficients.put("cm", 0.01); coefficients.put("inch", 0.0254); - 转换逻辑统一为:输入值 × 输入单位系数 ÷ 目标单位系数
- 新增单位只需往 map 里加一行,不用改计算逻辑
- 注意单位名大小写敏感,建议统一转小写处理:
unit.toLowerCase()
运行时报 java.util.InputMismatchException 怎么快速定位?
这是 Scanner 在期望读数字时遇到了非数字字符(比如用户输了个“123kg”或直接回车)。它不会提示哪一行出错,只抛异常。
立即学习“Java免费学习笔记(深入)”;
- 在
nextDouble()前加hasNextDouble()判断:if (scanner.hasNextDouble()) { value = scanner.nextDouble(); } else { System.out.println("请输入有效数字"); scanner.next(); // 跳过非法输入 } - 不要依赖 try-catch 包裹整个输入流程——掩盖了输入校验责任
- 调试时可先打印
scanner.nextLine()的原始字符串,确认是否含不可见字符(如全角空格)










