在Java中如何开发小型成绩录入工具_Java集合应用解析

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

Java 小型成绩录入工具的核心不在于“功能多”,而在于用对集合——ArrayList 存学生列表、HashMap 做学号查成绩、TreeSet 保证科目去重且有序,三者配合就能避开大多数设计翻车点。

ArrayList 管理学生主体,别用数组

学生是动态增删的,硬编码数组长度会卡死后续录入。每个 Student 对象至少含 idString)、namescoresMap)。不用 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);

注意点:

  • 科目名统一用 trim() 后的 String,防止“Java编程 ”和“Java编程”被当两门课
  • null 分数?不行。用 Double.NaN 或单独字段 isAbsent 标记缺考,避免 get() 返回 null 导致 NPE
  • 遍历时用 entrySet(),别用 keySet() 再 get——少一次哈希查找

TreeSet

维护全局科目列表,自动排序+去重

所有学生科目汇总后要展示、统计、导出,手动维护易漏。初始化一个 TreeSet,每次新增成绩就 subjects.add(subjectName)

TreeSet subjects = 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 时丢前导零

真正麻烦的不是代码量,而是边界:学号含字母怎么比大小、科目名中英文混排的排序规则、空分数怎么参与平均分计算。这些细节不提前想清楚,后面改集合结构成本远高于初期多写两行校验逻辑。