【Java类集】_Map接口使用的注意事项笔记(亲测实例)

来源:互联网 发布:linux所有版本 编辑:程序博客网 时间:2024/06/17 02:56

【Java类集】_Map接口使用的注意事项笔记(亲测实例)

分类: Java
【Java类集】_Map接口使用的注意事项笔记

本章目标:

掌握Map接口的输出操作
掌握Map接口中Key类的定义标准

Map接口输出

对于Map接口来说,其本身是不能直接使用迭代(例如:Iterator、foreach)来进行输出的,因为Map中每个位置存放的是一对值(key->value),而Iterator中每次只能找到一个值。所以,如果此时非要使用迭代进行输出的话,则必须按以下步骤完成(以Iterator输出方法为例):

1、将Map的实例通过entrySet()方法变为Set接口对象
2、通过Set接口实例为Iterator实例化
3、通过Iterator迭代输出,每个内容都是Map.Entry的对象
4、通过Map.Entry进行key->value的分离

但是,在操作前必须说明的,Map接口一般只作为查找使用,输出毕竟是少数。
[java] view plaincopyprint?
  1. import java.util.HashMap;  
  2. import java.util.Map;  
  3. import java.util.Set;  
  4. import java.util.Iterator;  
  5. public class IteratorDemo04{  
  6.     public static void main(String args[]){  
  7.         Map<String,String> map = null;  
  8.         map = new HashMap<String,String>();  
  9.         map.put("mldn","www.mldn.cn");  
  10.         map.put("zhinangtuan","www.zhinangtuan.cn");  
  11.         map.put("mldnjava","www.mldnjava.cn");  
  12.         Set<Map.Entry<String,String>> allSet = null;  
  13.         allSet = map.entrySet();  
  14.         Iterator<Map.Entry<String,String>> iter = null;  
  15.         iter = allSet.iterator();  
  16.         while(iter.hasNext()){  
  17.             Map.Entry<String,String> me = iter.next();  
  18.             System.out.println(me.getKey()+"-->"+me.getValue());  
  19.         }  
  20.     }  
  21. }  


输出:
zhinangtuan-->www.zhinangtuan.cn
mldn-->www.mldn.cn
mldnjava-->www.mldnjava.cn

第一种方式,使用Iterator完成。当然,在JDK1.5之后也可以使用foreach完成。
[java] view plaincopyprint?
  1. import java.util.HashMap;  
  2. import java.util.Map;  
  3. import java.util.Set;  
  4. import java.util.Iterator;  
  5. public class IteratorDemo04{  
  6.     public static void main(String args[]){  
  7.         Map<String,String> map = null;  
  8.         map = new HashMap<String,String>();  
  9.         map.put("mldn","www.mldn.cn");  
  10.         map.put("zhinangtuan","www.zhinangtuan.cn");  
  11.         map.put("mldnjava","www.mldnjava.cn");  
  12.         Set<Map.Entry<String,String>> allSet = null;  
  13.         for(Map.Entry<String,String> me:map.entrySet()){  
  14.             System.out.println(me.getKey()+"-->"+me.getValue());  
  15.         }  
  16.     }  
  17. }  



输出:
zhinangtuan-->www.zhinangtuan.cn
mldn-->www.mldn.cn
mldnjava-->www.mldnjava.cn

这两种输出形式最终实际上还是以Collection的形式输出,只是以Map.Entry作为内容的操作类型。
在Map中,可以使用任意的类型作为key和value,那么使用非系统类也可以。

[java] view plaincopyprint?
  1. import java.util.Map;  
  2. import java.util.HashMap;  
  3. class Person{  
  4.     private String name;  
  5.     private int age;  
  6.     public Person(String name,int age){  
  7.         this.name = name;  
  8.         this.age = age;      
  9.     }  
  10.     public String toString(){  
  11.         return "姓名:"+this.name+";年龄:"+this.age;      
  12.     }  
  13. }  
  14. public class HashMapDemo05{  
  15.     public static void main(String args[]){  
  16.         Map<String,Person> map = null;  
  17.         map = new HashMap<String,Person>();  
  18.         map.put(new Person("张三",30),"zhangsan");//增加内容  
  19.         System.out.println(map.get(new Person("张三",30)));      
  20.     }  
  21. }  


此时,只是将自定义的类作为key,但是在取值的时候发现取不了了,返回结果为null,那么为什么之前的String可以,但是自定义的类不存在呢?

实际上,对于匹配过程来讲呢,有一个特点,即:对象要一样才可以将内容查询出来。

[java] view plaincopyprint?
  1. import java.util.Map;  
  2. import java.util.HashMap;  
  3. class Person{  
  4.     private String name;  
  5.     private int age;  
  6.     public Person(String name,int age){  
  7.         this.name = name;  
  8.         this.age = age;      
  9.     }  
  10.     public String toString(){  
  11.         return "姓名:"+this.name+";年龄:"+this.age;      
  12.     }  
  13. }  
  14. public class HashMapDemo06{  
  15.     public static void main(String args[]){  
  16.         Map<Person,String> map = null;  
  17.         map = new HashMap<Person,String>();  
  18.         Person per = new Person("张三",30);  
  19.         map.put(per,"zhangsan");//增加内容  
  20.         System.out.println(map.get(per));      
  21.     }  
  22. }  


输出:
zhangsan

可是这样并不是解决问题的方法,因为不可能将Person的per对象到处带走啊,应该像String一样,可以使用匿名对象的形式找到内容。那么此时,实际上就需要按照与Set接口中判断重复元素方式一样,进行方法的覆写。

注意事项:直接使用非系统类作为key

如果要使用非系统类作为Map的key,则此类必须覆写Object类中的以下两个方法:
hashCode()
equals()

[java] view plaincopyprint?
  1. import java.util.Map;  
  2. import java.util.HashMap;  
  3. class Person{  
  4.     private String name;  
  5.     private int age;  
  6.     public Person(String name,int age){  
  7.         this.name = name;  
  8.         this.age = age;      
  9.     }  
  10.     public String toString(){  
  11.         return "姓名:"+this.name+";年龄:"+this.age;      
  12.     }  
  13.     public boolean equals(Object obj){  
  14.         if(this==obj){  
  15.             return true;  
  16.         }  
  17.         if(!obj instanceof Person){  
  18.             return false;  
  19.         }  
  20.         Person per = (Person) obj;  
  21.         if(this.name.equals(per.name)&&this.age==per.age){  
  22.             return true;  
  23.         }else{  
  24.             return false;  
  25.         }  
  26.     }  
  27.     public int hashCode(){  
  28.         return this.name.hashCode()*this.age;  
  29.     }  
  30. }  
  31. public class HashMapDemo07{  
  32.     public static void main(String args[]){  
  33.         Map<Person,String> map = null;  
  34.         map = new HashMap<Person,String>();  
  35.         map.put(new Person("张三",30),"zhangsan");//增加内容  
  36.         System.out.println(map.get(new Person("张三",30)));      
  37.     }  
  38. }  



输出:
zhangsan

作为key,或者更准确的说是作为对象的时候,实际上是依靠hashCode()和equals()来判断两个匿名对象是否相等,这一点由系统内容自动完成。

总结:
1、Map可以使用迭代输出
    Map->entrySet->Set->Iterator->Map.Entry->key和value
2、如果使用非系统类作为key,则一定保证覆写equals和hashCode()方法,否则无效。
0 0
原创粉丝点击