风居住de的街道

map的四种遍历方式

map是Java中非常常用的一种数据结构,但map不同于set和list都继承自Collection接口。

所以map没有实现Collection的Iterator 方法,自身没有迭代器来遍历元素。

构造一个map

  1. Map<String, String> map = new HashMap<String, String>();    
  2. map.put("001", "hello");    
  3. map.put("002", "world");    
  4. map.put("003", "main");    

想遍历这个map,那map通常的遍历方式有哪几种呢?

 

 

这里我们介绍常用的四种方式:keySet集合迭代,entrySet集合迭代,keySet 集合for-each 循环,entrySet集合for-each循环。

 

方法1 keySet集合迭代

 
  1. // method1  
  2. Set<String> keySet = map.keySet();  
  3. Iterator<String> it = keySet.iterator();  
  4. while (it.hasNext()) {  
  5.     String key = it.next();  
  6.     System.out.println(key + "=" + map.get(key));  
  7. }  

 

方法2 entrySet集合迭代

 
  1. // method2  
  2. Set<Map.Entry<String, String>> entrySet = map.entrySet();  
  3. Iterator<Map.Entry<String, String>> meIt = entrySet.iterator();  
  4. while (meIt.hasNext()) {  
  5.     Entry<String, String> entry = meIt.next();  
  6.     System.out.println(entry.getKey() + "=" + entry.getValue());  
  7. }  

 

方法3 keySet集合for-each循环

  1. // method3  
  2. for (String key : map.keySet()) {  
  3.     System.out.println(key + "=" + map.get(key));  
  4. }  

 

 

方法4 entrySet集合for-each循环

 
  1. // method4  
  2. for (Map.Entry<String, String> entry : map.entrySet()) {  
  3.     System.out.println(entry.getKey() + "=" + entry.getValue());  
  4. }  

四种方式中,method1 和 method2 是通过迭代器来显示完成的,method3 和 method4 是通过for-each来隐式的通过迭代器来完成的。

同时 method1 和 method3 是通过key的集合来完成的,method2 和 method4 是通过entry 的集合来完成的。

 

 

 

方法1 和方法2 的区别

一个是获取keySet ,一个是获取entrySet

推荐使用entrySet 的方式去获取,查看map通过key获取value的方法

  1. public V get(Object key) {  
  2.     if (key == null)  
  3.         return getForNullKey();  
  4.     Entry<K,V> entry = getEntry(key);  
  5.   
  6.     return null == entry ? null : entry.getValue();  
  7. }  

也是先获取该key对应的entry,然后再获取value值,所以,推荐使用entrySet 方法,再遍历entry集合的方式来遍历map

 

map 接口还有一个方法 values() ,由于仅能取到所有的value值,而取不到key值,所以在这里就算不上遍历map了,只能算上遍历map的value值。

 

posted on 2016-12-15 15:51  风居住de街道  阅读(206)  评论(0编辑  收藏  举报

导航