按回车跳过后续输入是因为nextInt()等不读取换行符,导致nextLine()立即读到空字符串;应在nextInt()后加scanner.nextLine()清缓存,或统一用nextLine()配合parseXXX()转换。
这是初学者最常遇到的阻塞问题:调用 nextLine() 前如果用了 nextInt() 或 nextDouble(),后者不会消费换行符,导致紧接着的 nextLine() 立即读到空字符串。
nextInt() 只读数字,把回车留在输入缓冲区;nextLine() 一执行就“吃掉”这个残留回车nextInt() 后手动加一行 scanner.nextLine(); 清空缓冲区nextLine() 读所有输入,再用 Integer.parseInt() 或 Double.parseDouble() 转换Scanner scanner = new Scanner(System.in);
System.out.print("请输入学号:");
String id = scanner.nextLine(); // 安全
System.out.print("请输入成绩:");
double score = Double.parseDouble(scanner.nextLine()); // 避免 nextDouble() + nextLine() 组合不要。直接暴露字段(如 public String name;)会破坏封装性,后续无法加校验、日志或逻辑变更。
private,用 public 的 getter/setter 控制访问if (score 100) throw new IllegalArgumentException("成绩必须在 0-100 之间");
如 IntelliJ)能一键生成 getter/setter,不必手写冗余代码常见错误是在 for 循环中边遍历边 remove(),导致后续元素前移但循环变量 i 仍自增,跳过下一个元素,甚至引发 IndexOutOfBoundsException。
for (int i = 0; i
for (int i = list.size()-1; i >= 0; i--)
Iterator it = list.iterator(); while (it.hasNext()) { if (条件) it.remove(); }
removeIf() —— students.removeIf(s -> s.getId().equals(id));
学生成绩管理系统里,用 double 完全够用,也更轻量;BigDecimal 是为金融计算设计的,过度设计反而增加复杂度。
double 的精度误差(如 0.1 + 0.2 = 0.30000000000000004)在成绩场景下无实际影响,显示时用 String.format("%.1f", score) 即可控制小数位==,改用 Math.abs(a - b)
BigDecimal
真正容易被忽略的是输入校验和边界处理:比如学号为空、成绩输成字母、删除不存在的学生——这些不是“功能做完就完事”,而是用户第一次运行就可能触发的崩溃点。先让程序不崩,再谈功能完整。