Java小型成绩录入工具核心是合理选用ArrayList、HashMap、TreeSet:ArrayList存学生列表支持动态增删,HashMap以科目名为键存单个学生成绩确保可定位,TreeSet维护全局科目实现去重有序。

Java 小型成绩录入工具的核心不在于“功能多”,而在于用对集合——ArrayList 存学生列表、HashMap 做学号查成绩、TreeSet 保证科目去重且有序,三者配合就能避开大多数设计翻车点。
用 ArrayList 管理学生主体,别用数组
学生是动态增删的,硬编码数组长度会卡死后续录入。每个 Student 对象至少含 id(String)、name、scores(Map)。不用 LinkedList——录入是尾部追加,ArrayList 的随机访问和尾插性能更稳。
- 避免把
scores设为List:科目名丢失,后期无法区分“数学”还是“英语” - 构造时别直接 new
HashMap,用new HashMap(16, 0.75f)预估容量,减少扩容抖动 - 学号重复要拦截:
if (students.stream().anyMatch(s -> s.getId().equals(newId)))比遍历快,但数据量大时建议改用HashSet存已用学号做 O(1) 判断
HashMap 存单个学生成绩,键必须是科目名字符串
别用下标(如 scores.get(0))对应科目——一旦删科或顺序变动,全乱。用科目名作 key,查分、更新、删科都靠它定位:
student.getScores().put("Java编程", 89.5);
student.getScores().put("数据库原理", 92.0);
注意点:
立即学习“Java免费学习笔记(深入)”;
- 科目名统一用 trim() 后的
String,防止“Java编程 ”和“Java编程”被当两门课 - 存
null分数?不行。用Double.NaN或单独字段isAbsent标记缺考,避免get()返回 null 导致 NPE - 遍历时用
entrySet(),别用keySet()再 get——少一次哈希查找
用 TreeSet 维护全局科目列表,自动排序+去重
所有学生科目汇总后要展示、统计、导出,手动维护易漏。初始化一个 TreeSet,每次新增成绩就 subjects.add(subjectName):
TreeSetsubjects = new TreeSet<>(); // 录入时 subjects.addAll(student.getScores().keySet());
好处:
- 自然按字典序排好(“Java编程”在“数据库原理”前),省去每次
Collections.sort() - 自动过滤重复科目,比如张三录了“Java”,李四再录“java”(大小写不同)?得先
toLowerCase()规范化,否则TreeSet当两个科目 - 不能用
HashSet替代——后续生成报表时顺序混乱,用户看着费劲
控制台录入时,Scanner 的换行陷阱必须处理
调 nextInt() 或 nextDouble() 后,回车符留在缓冲区,紧接着 nextLine() 会立刻读到空字符串。这是新手最常卡住的地方:
- 统一用
nextLine()读所有输入,数字类型再Double.parseDouble()转——简单粗暴,无坑 - 输入校验别只靠 try-catch:先
str.trim().isEmpty()判空,再检查是否含非数字字符(如“89.5a”) - 学号用
String类型存,别转int——“00123”转 int 变 123,导出 Excel 时丢前导零
真正麻烦的不是代码量,而是边界:学号含字母怎么比大小、科目名中英文混排的排序规则、空分数怎么参与平均分计算。这些细节不提前想清楚,后面改集合结构成本远高于初期多写两行校验逻辑。










