题目描述:
每位学生(姓名,年龄)都有自己的家庭住址。那么,既然有对应关系,则将学生对象和家庭住址存储到map集合中。学生作为键, 家庭住址作为值。
代码实现:
1.编写学生类:
public class Student {
private String name;
private int age;
public Student() {
}
public Student(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public int hashCode() {
return name.hashCode()+age*38 ;
}
@Override
public boolean equals(Object obj) {
Student student=(Student)obj;
return this.name.equals(student.name)&&this.age==student.age;
}
@Override
public String toString() {
return name+age;
}
}
2.编写测试类
public class Demomaptest1 {
public static void main(String[] args) {
HashMap<Student, String> map = new HashMap<>();
map.put(new Student("雅并", 18), "七秀");
map.put(new Student("锦瑟", 18), "五毒");
map.put(new Student("若雪", 18), "长歌");
//方法一 keysrt取到我们的key(集合)
Set<Student>set=map.keySet();
//遍历取值
Iterator<Student> iter=set.iterator();
while (iter.hasNext()){
Student key= iter.next();
String value=map.get(key);
System.out.println(key+"------"+value);
}
System.out.println("—————————————");
//方法二 entryset遍历取值
Set<Map.Entry<Student,String>> set1=map.entrySet();
for (Map.Entry<Student, String> studentStringEntry : set1) {
String value= studentStringEntry.getValue();
Student key= studentStringEntry.getKey();
System.out.println(key+"-------"+value);
}
}
}
运行结果:
注意:
当给HashMap中存放自定义对象时,如果自定义对象作为key存在,这时要保证对象唯一,必须复写对象的hashCode和equals方法(回顾HashSet存放自定义对象)
如果要保证map中存放的key和取出的顺序一致,可以使用java.util.LinkedHashMap
集合来存放。