Java中读取Map的两种方法对比

来源:互联网 发布:java xml解析器 编辑:程序博客网 时间:2024/05/16 19:16

原文:http://blog.csdn.net/blueheart20/article/details/45173621

引言: 在Java中Map的使用非常频繁,我们经常会需要对Map进行遍历和读取,下面将展示两种遍历的方法以及简要分析。

1.  遍历Map方法A

[html] view plain copy
  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. }  
2. 遍历Map方法B

[html] view plain copy
  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. }  
3. 分析遍历方法

   方法A:  在遍历中一次读取Map.Entry,然后直接获取的值。

   方法B:   基于keySet则是,先遍历,然后再从Map中读取信息。

4. 性能测试

[java] view plain copy
  1. import java.util.HashMap;  
  2. import java.util.Iterator;  
  3. import java.util.Map;  
  4.    
  5. import org.junit.BeforeClass;  
  6. import org.junit.Test;  
  7.   
  8. public class MapLoopA {  
  9.     private static Map<Integer, String> infos = new HashMap<Integer, String>();  
  10.       
  11.     @BeforeClass  
  12.     public static void setUp() {  
  13.         for (int i=0; i<1000000; i++) {  
  14.             infos.put(i, "test information" + i);  
  15.         }  
  16.         System.out.println("setUp is done.");  
  17.     }  
  18.   
  19.     @Test  
  20.     public void testMapLoopA() {  
  21.         Iterator<Map.Entry<Integer, String>> iterator = infos.entrySet().iterator();  
  22.         long startTime = System.currentTimeMillis();  
  23.         while (iterator.hasNext()) {  
  24.             Map.Entry<Integer, String> entry = iterator.next();  
  25.             int key = entry.getKey();  
  26.             String val = entry.getValue();  
  27.         }  
  28.           
  29.         System.out.println("A solution takes in looping Map with 1000000 entries:"  
  30.                     + (System.currentTimeMillis()-startTime) + " milli seconds");  
  31.     }  
  32.       
  33.     @Test  
  34.     public void testMapLoopB() {  
  35.         Iterator<Integer> iterator = infos.keySet().iterator();  
  36.         long startTime = System.currentTimeMillis();  
  37.         while (iterator.hasNext()) {              
  38.             int key = iterator.next();  
  39.             String val = infos.get(key);  
  40.         }  
  41.           
  42.         System.out.println("B solution takes in looping Map with 1000000 entries:" +  
  43.                    (System.currentTimeMillis()-startTime) + " milli seconds");  
  44.     }  
  45. }  
测试结果:

  

由此可见,在Map中存放1000000个数据,并在此数据集合中,进行遍历。效率上差异将近1倍的性能差异。

5. 总结

    方法A的效率总体要高一些。一般推荐大家使用方法A。