用ArrayList+Scanner实现学生CRUD:建Student类(含id/name/age、全参构造、getter/setter、toString),增用add(new Student()),查用遍历+break,删用removeIf避免并发异常,输入统一用nextLine().trim()防换行残留,操作失败必须提示。

用 ArrayList + Scanner 实现最简 CRUD,适合刚学完基础语法的学生
不需要数据库、不引入框架,纯 Java 集合 + 控制台交互就能跑通完整流程。核心是把 Student 类建好,再用 ArrayList 当内存数据库。
常见错误:学生类字段没加 public 或没写 toString(),导致打印出来是 Student@1b6d3586;或者增删时忘记用 new Student(...) 实例化对象,直接传 null。
-
Student类至少包含id(int或String)、name、age三个字段,提供全参构造 + getter/setter - 增:用
list.add(new Student(...)),别漏new - 查:遍历用
for (Student s : list),按id查时建议加break提前退出 - 删:用
list.removeIf(s -> s.getId() == targetId)最安全;避免边遍历边remove()导致ConcurrentModificationException
public class Student {
private int id;
private String name;
private int age;
public Student(int id, String name, int age) {
this.id = id;
this.name = name;
this.age = age;
}
// getter/setter 省略
@Override
public String toString() {
return "Student{id=" + id + ", name='" + name + "', age=" + age + "}";
}
}
为什么不用 HashMap 而坚持用 ArrayList?
初学者容易想“用 HashMap 查得更快”,但实际会踩三个坑:一是 ID 重复时自动覆盖,二是删除后无法保持插入顺序(影响后续按序显示),三是学生作业常要求“显示全部学生”并编号(1. 张三、2. 李四),ArrayList 天然支持索引。
性能上,百条以内数据,ArrayList 的线性查找和 HashMap 的哈希查找差距可忽略;而维护成本低得多。
立即学习“Java免费学习笔记(深入)”;
- 如果真要用
HashMap,必须确保id唯一且非空,否则put()会静默覆盖 -
HashMap的keySet()或values()返回的集合不保证顺序,System.out.println(map.values())可能每次输出顺序不同 - 作业里若要求“第 N 个学生”,ArrayList 可直接
list.get(n-1),HashMap 得转成list再取,多此一举
Scanner 输入整数时卡住?多半是 nextLine() 和 nextInt() 混用惹的祸
典型现象:输入学生年龄后,紧接着的姓名输入直接跳过,变成空字符串。这是因为 nextInt() 不读取换行符,下一次 nextLine() 立刻读到那个残留的 \n。
解决方法统一用 nextLine(),再手动转换:
- 读整数:
int id = Integer.parseInt(scanner.nextLine().trim()) - 读字符串:
String name = scanner.nextLine().trim() - 所有输入后都加
.trim(),防用户多敲空格 - 加
try-catch捕获NumberFormatException,提示“请输入有效数字”而不是程序崩溃
删/改操作找不到目标 ID 时,别让程序静默失败
学生常写成:if (s.getId() == targetId) { list.remove(s); break; } —— 这样找不到时完全没反馈,用户以为删成功了。
必须显式标记是否命中:
- 删之前设
boolean found = false,循环中匹配则found = true; list.remove(...) - 循环结束后检查
if (!found) System.out.println("未找到 ID 为 " + targetId + " 的学生"); - 改操作同理:先查是否存在,存在才改字段,不存在就报错
- 控制台项目里,“没反应”比“报错”更难调试,宁可多打一行提示










