
本教程详细讲解了如何在java中管理和遍历嵌套的`hashmap`结构,特别是当内部`hashmap`被封装在自定义类中时。通过构建一个成绩记录系统示例,演示了如何设计封装类、实现数据添加逻辑,以及使用多层迭代器有效访问和处理复杂数据,确保代码的模块化和可读性。
在Java应用程序开发中,我们经常需要处理复杂的数据结构,例如,一个学生成绩记录系统可能需要存储每个学期(semester)的多门课程(subject)及其对应的分数(mark)。这种场景下,使用嵌套的 HashMap 结构,并结合自定义的封装类,是一种常见且高效的解决方案。本文将通过一个具体的成绩记录系统示例,详细阐述如何设计、添加数据以及遍历这种嵌套的 HashMap 结构。
首先,我们需要一个类来封装单一学期内的课程及其成绩。这个类,我们称之为 Marks,将包含一个 HashMap 来存储课程名(String)和对应的分数(Integer)。为了遵循良好的面向对象设计原则,这个内部的 HashMap 应该被声明为 private final,并通过公共方法提供受控的访问。
import java.util.HashMap;
import java.util.Map;
/**
* Marks类用于封装一个学期的课程成绩。
*/
public class Marks {
// 使用private final修饰符封装课程-成绩映射
private final Map<String, Integer> subjectMark = new HashMap<>();
/**
* 向当前学期添加或更新一门课程的成绩。
* @param subject 课程名称
* @param mark 课程分数
*/
public void addSubjectMark(String subject, int mark) {
subjectMark.put(subject, mark);
}
/**
* 获取当前学期的所有课程成绩映射。
* 外部通过此方法访问内部的HashMap。
* @return 包含课程名和分数的Map
*/
public Map<String, Integer> getSubjectMark() {
return subjectMark;
}
}在 Marks 类中,getSubjectMark() 方法至关重要,它充当了内部 HashMap 的访问器(accessor),允许外部类在不直接暴露内部实现细节的情况下获取数据。
接下来,我们需要一个 RecordBook 类来管理所有学期的成绩。这个类将使用一个 HashMap,其中键是学期号(Integer),值是对应的 Marks 对象。
立即学习“Java免费学习笔记(深入)”;
import java.util.HashMap;
import java.util.Map;
/**
* RecordBook类用于管理所有学期的成绩记录。
*/
public class RecordBook {
// 存储学期号到Marks对象的映射
private final Map<Integer, Marks> semesterSubjectMark = new HashMap<>();
/**
* 为指定学期添加一门课程的成绩。
* 如果该学期尚无记录,则会创建新的Marks对象。
* @param semester 学期号
* @param subject 课程名称
* @param mark 课程分数
*/
public void addSemester(int semester, String subject, int mark) {
// 尝试获取指定学期对应的Marks对象
Marks marks = semesterSubjectMark.get(semester);
// 如果该学期是第一次添加成绩,则创建新的Marks对象并放入Map
if (marks == null) {
marks = new Marks();
semesterSubjectMark.put(semester, marks);
}
// 调用Marks对象的方法添加课程成绩
marks.addSubjectMark(subject, mark);
}
/**
* 示例方法:计算并打印所有学期的平均GPA。
* 此方法演示了如何遍历嵌套的HashMap结构。
*/
public void gpa() {
int totalMark = 0;
int totalCredit = 0; // 假设每门课程都有一个学分,这里简化处理
// 第一层遍历:遍历所有学期
for (Map.Entry<Integer, Marks> semesterEntry : semesterSubjectMark.entrySet()) {
Integer semester = semesterEntry.getKey(); // 获取学期号
Marks marks = semesterEntry.getValue(); // 获取该学期对应的Marks对象
System.out.println("--- 学期 " + semester + " ---");
// 第二层遍历:遍历当前学期的所有课程成绩
// 通过marks.getSubjectMark()获取内部的HashMap
for (Map.Entry<String, Integer> subjectEntry : marks.getSubjectMark().entrySet()) {
String subject = subjectEntry.getKey(); // 获取课程名称
int mark = subjectEntry.getValue(); // 获取课程分数
int credit = 1; // 简化处理,假设所有课程学分为1
// 实际应用中,学分可能根据课程类型或固定值确定
// if (subject.equals("Math")) { credit = 2; }
// if (subject.equals("English")) { credit = 1; }
totalMark += mark * credit;
totalCredit += credit;
System.out.println(" 课程: " + subject + ", 分数: " + mark + ", 学分: " + credit);
}
}
if (totalCredit > 0) {
System.out.println("\n--- 总结 ---");
System.out.println("总学分: " + totalCredit);
System.out.println("总加权分数: " + totalMark);
System.out.println("平均GPA: " + (double) totalMark / totalCredit);
} else {
System.out.println("没有可计算的成绩记录。");
}
}
}在 RecordBook 类的 addSemester 方法中,我们首先检查指定学期是否已经存在 Marks 对象。如果不存在,则创建一个新的 Marks 实例并将其添加到 semesterSubjectMark 中。这种“按需创建”的模式可以有效管理内存,并确保数据的正确性。
遍历这种嵌套的 HashMap 结构是本教程的核心。在 RecordBook 类的 gpa() 方法中,我们展示了如何使用两层 for-each 循环来访问所有数据:
这种分层遍历的方式清晰地反映了数据的层次结构,使得代码逻辑易于理解和维护。
为了演示上述类的使用,我们可以创建一个主方法:
public class Main {
public static void main(String[] args) {
RecordBook recordBook = new RecordBook();
// 添加学期1的成绩
recordBook.addSemester(1, "高等数学", 90);
recordBook.addSemester(1, "大学英语", 85);
recordBook.addSemester(1, "数据结构", 92);
// 添加学期2的成绩
recordBook.addSemester(2, "操作系统", 88);
recordBook.addSemester(2, "计算机网络", 80);
recordBook.addSemester(2, "Java编程", 95);
recordBook.addSemester(2, "高等数学", 80); // 学期2也有高等数学
// 计算并打印GPA
recordBook.gpa();
}
}运行 Main 类将输出所有学期的课程成绩,并计算出总的平均GPA。
通过本教程,我们学习了如何在Java中有效地管理和遍历一个包含自定义封装类的嵌套 HashMap 结构。关键在于合理设计封装类(如 Marks),通过公共方法提供受控的数据访问,并在更高层次的聚合类(如 RecordBook)中实现数据添加和多层迭代逻辑。这种方法不仅保证了代码的模块化和可读性,也为处理更复杂的数据结构奠定了坚实的基础。
以上就是Java中管理和遍历嵌套HashMap:以成绩记录系统为例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号