HashMap存储自定义对象

将学生对象和学生的归属地通过键与值存储到map集合中。

  1. import java.util.HashMap;
  2. import java.util.Iterator;
  3. import java.util.Set;
  4. class Student {
  5. String name;
  6. int age;
  7. public Student(String name,int age){
  8. super();
  9. this.name=name;
  10. this.age=age;
  11. }
  12. public String getName(){
  13. return name;
  14. }
  15. public void setName(String name){
  16. this.name=name;
  17. }
  18. public int getAge(){
  19. return age;
  20. }
  21. public void setAge(int age){
  22. this.age=age;
  23. }
  24. }
  25. public class HashMapDemo{
  26. public static void main(String[] args){
  27. HashMap<Student,String> hm=new HashMap<Student,String>();
  28. hm.put(new Student(“lisi”,38),“北京”);
  29. hm.put(new Student(“zhaosi”,34),“上海”);
  30. hm.put(new Student(“xiaoqiang”,31),“沈阳”);
  31. hm.put(new Student(“wangcai”,28),“大连”);
  32. hm.put(new Student(“zhaosi”,34),“铁岭”);
  33. Set<Student> keySet=hm.keySet();
  34. Iterator<Student> it=keySet.iterator();
  35. while(it.hasNext()){
  36. Student key=it.next();
  37. String value=hm.get(key);
  38. System.out.println(key.getName()+“:”+key.getAge()+“…”+value);
  39. }
  40. }
  41. }
运行结果:


当键一样时,其值并没有被覆盖,所以要判断键是否相同,HashMap需要定义hashCode和equals方法,在Student类中要复写方法:

  1. import java.util.HashMap;
  2. import java.util.Iterator;
  3. import java.util.Set;
  4. class Student {
  5. String name;
  6. int age;
  7. public Student(String name,int age){
  8. super();
  9. this.name=name;
  10. this.age=age;
  11. }
  12. public String getName(){
  13. return name;
  14. }
  15. public void setName(String name){
  16. this.name=name;
  17. }
  18. public int getAge(){
  19. return age;
  20. }
  21. public void setAge(int age){
  22. this.age=age;
  23. }
  24. public int hashCode(){ //复写hashCode()
  25. return name.hashCode()+age;
  26. }
  27. public boolean equals(Object obj){ //复写equals
  28. if(this==obj) return true;
  29. if(!(obj instanceof Student)) throw new ClassCastException("类型错误"); //输入类型错误
  30. Student p = (Student)obj;//强制转换
  31. return this.name.equals(p.name) && this.age==p.age; //说明姓名和年龄相同则为同一元素
  32. }
  33. }
  34. public class HashMapDemo{
  35. public static void main(String[] args){
  36. HashMap<Student,String> hm=new HashMap<Student,String>();
  37. hm.put(new Student("lisi",38),"北京");
  38. hm.put(new Student("zhaosi",34),"上海");
  39. hm.put(new Student("xiaoqiang",31),"沈阳");
  40. hm.put(new Student("wangcai",28),"大连");
  41. hm.put(new Student("zhaosi",34),"铁岭");
  42. Set<Student> keySet=hm.keySet();
  43. Iterator<Student> it=keySet.iterator();
  44. //以下被注释的代码可以替换上面两句:
  45. //Iterator<Student> it=hm.keySet().iterator();
  46. while(it.hasNext()){
  47. Student key=it.next();
  48. String value=hm.get(key);
  49. System.out.println(key.getName()+":"+key.getAge()+"..."+value);
  50. }
  51. }
  52. }
运行结果:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值