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的遍歷方法和以上的差不多!
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章