HashMap遍历的两种方式

第一种: 
Java代码  收藏代码
  1. Map map = new HashMap();  
  2. Iterator iter = map.entrySet().iterator();  
  3. while (iter.hasNext()) {  
  4.     Map.Entry entry = (Map.Entry) iter.next();  
  5.     Object key = entry.getKey();  
  6.     Object val = entry.getValue();  
  7. }  

效率高,以后一定要使用此种方式! 
第二种: 
Java代码  收藏代码
  1. Map map = new HashMap();  
  2. Iterator iter = map.keySet().iterator();  
  3. while (iter.hasNext()) {  
  4.     Object key = iter.next();  
  5.     Object val = map.get(key);  
  6. }  

效率低,以后尽量少使用! 

例: 
HashMap的遍历有两种常用的方法,那就是使用keyset及entryset来进行遍历,但两者的遍历速度是有差别的,下面请看实例: 

Java代码  收藏代码
  1. public class HashMapTest {  
  2. public static void main(String[] args) ...{  
  3.   HashMap hashmap = new HashMap();  
  4.   for (int i = 0; i < 1000; i ) ...{  
  5.    hashmap.put("" i, "thanks");  
  6.   }  
  7.   
  8.   long bs = Calendar.getInstance().getTimeInMillis();  
  9.   Iterator iterator = hashmap.keySet().iterator();    
  10.   while (iterator.hasNext()) ...{     
  11.    System.out.print(hashmap.get(iterator.next()));  
  12.   }  
  13.   System.out.println();  
  14.   System.out.println(Calendar.getInstance().getTimeInMillis() - bs);  
  15.   listHashMap();  
  16. }  
  17.   
  18.   public static void listHashMap() ...{  
  19.   java.util.HashMap hashmap = new java.util.HashMap();  
  20.   for (int i = 0; i < 1000; i ) ...{  
  21.    hashmap.put("" i, "thanks");  
  22.   }  
  23.   long bs = Calendar.getInstance().getTimeInMillis();    
  24.   java.util.Iterator it = hashmap.entrySet().iterator();  
  25.   while (it.hasNext()) ...{  
  26.    java.util.Map.Entry entry = (java.util.Map.Entry) it.next();  
  27.    // entry.getKey() 返回与此项对应的键  
  28.    // entry.getValue() 返回与此项对应的值  
  29.    System.out.print(entry.getValue());  
  30.   }  
  31.   System.out.println();  
  32.   System.out.println(Calendar.getInstance().getTimeInMillis() - bs);  
  33. }  
  34. }  


对于keySet其实是遍历了2次,一次是转为iterator,一次就从hashmap中取出key所对于的value。而entryset只是遍历了第一次,他把key和value都放到了entry中,所以就快了。 

注:Hashtable的遍历方法和以上的差不多!

你可能感兴趣的:(java容器)