用ArrayList+Student类可快速搭建内存版成绩管理系统,Student需含id、name和subjectScores(Map),用Stream操作增删查,录入时校验分数≥0。

用 ArrayList + Student 类快速搭建内存版成绩管理
不需要数据库也能跑通核心流程,关键在于把学生、课程、成绩三者关系建模清楚。Student 类至少包含 id、name、subjectScores(如 Map),避免用三个平行数组硬凑——一改就不同步。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- 用
ArrayList存所有学生,增删查都走list.stream().filter(...).findFirst(),别手写 for 循环遍历 - 成绩录入时强制校验
score >= 0 && score ,否则存进去就是脏数据,后续统计全错 - 避免在
Student里直接存“平均分”字段——它应是计算结果,不是状态,否则修改单科成绩后忘记更新平均分,逻辑就裂了
导出 CSV 时中文乱码和格式错位怎么破
Java 默认用平台编码写文件,Windows 上是 GBK,但 Excel 打开 CSV 默认按 UTF-8 解码,不加 BOM 就全乱码。别信“改系统编码”这种方案,太重。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- 写文件必须显式指定
StandardCharsets.UTF_8,且第一行开头写\uFEFF(BOM):Files.write(path, content, StandardCharsets.UTF_8);
- CSV 字段含逗号、换行或双引号时,必须用双引号包裹该字段,并将原字段内双引号替换成两个双引号(Excel 标准规则)
- 别用
String.join(", ", ...)拼 CSV——它不处理转义,一遇到学生名叫 “张三,男” 就崩成两列
用 Scanner 读控制台输入时卡死或跳过 nextLine()
这是新手最常踩的坑:nextInt() 或 nextDouble() 不会消费回车符,紧接着调 nextLine() 就立刻返回空字符串,看起来像“跳过了”。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- 统一用
nextLine()读所有输入,再手动转类型:int id = Integer.parseInt(scanner.nextLine().trim());
- 对可能输错的数字输入,加
try-catch,别让一次输错导致整个程序退出 - 输入菜单选项时,用
switch (scanner.nextLine().trim())比 if-else 更清晰,也避免字符串比较漏掉trim()
想持久化但又不想配 MySQL?试试 ObjectInputStream/ObjectOutputStream
序列化不是银弹,但它对小规模、纯 Java 环境下的快速落地最轻量。前提是所有类都实现 Serializable,且字段不包含线程、IO 流等不可序列化对象。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- 给
Student加private static final long serialVersionUID = 1L;,否则类稍作修改(比如加个字段)就反序列化失败 - 保存时用
try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("data.ser"))) { oos.writeObject(students); } - 反序列化前先检查文件是否存在且非空,空文件会抛
EOFException,得捕获——没人喜欢一启动就崩溃
真正难的不是存数据,而是每次需求微调(比如要加“班级”字段、支持按学期筛选)时,旧序列化文件是否还能读。这类隐性兼容成本,比写一行 JDBC 还容易被忽略。










