隨筆 - 100  文章 - 50  trackbacks - 0
          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(3)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          收藏夾

          我收藏的一些文章!

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          第一種:
          Map map = new HashMap();
          Iterator iter = map.entrySet().iterator();
          while (iter.hasNext()) {
              Map.Entry entry = (Map.Entry) iter.next();
              Object key = entry.getKey();
              Object val = entry.getValue();
          }
          效率高,以后一定要使用此種方式!
          第二種:
          Map map = new HashMap();
          Iterator iter = map.keySet().iterator();
          while (iter.hasNext()) {
              Object key = iter.next();
              Object val = map.get(key);
          }
          效率低,以后盡量少使用!

          例:
          HashMap的遍歷有兩種常用的方法,那就是使用keyset及entryset來進行遍歷,但兩者的遍歷速度是有差別的,下面請看實例:

          public class HashMapTest {
          public static void main(String[] args) ...{
            HashMap hashmap = new HashMap();
            for (int i = 0; i < 100000; i ) ...{
             hashmap.put("" i, "test");
            }

            long bg = System.currentTimeMillis();
            Iterator iterator = hashmap.keySet().iterator();  
            while (iterator.hasNext()) {   
             System.out.print(hashmap.get(iterator.next()));
            }
            System.out.println();
            System.out.println(System.currentTimeMillis()- bg);
            listHashMap();
          }

            public static void listHashMap() ...{
            java.util.HashMap hashmap = new java.util.HashMap();
            for (int i = 0; i < 100000; i ) ...{
             hashmap.put("" i, "test");
            }
            long bg = System.currentTimeMillis();
            java.util.Iterator it = hashmap.entrySet().iterator();
            while (it.hasNext()) ...{
             java.util.Map.Entry entry = (java.util.Map.Entry) it.next();
             // entry.getKey() 返回與此項對應的鍵
             // entry.getValue() 返回與此項對應的值
             System.out.print(entry.getValue());
            }
            System.out.println();
            System.out.println(System.currentTimeMillis() - bg);
          }
          }

          對于keySet其實是遍歷了2次,一次是轉為iterator,一次就從hashmap中取出key所對于的value。而entryset只是遍歷了第一次,他把key和value都放到了entry中,所以就快了。
          posted on 2010-09-06 23:33 fly 閱讀(217) 評論(0)  編輯  收藏 所屬分類: java學習
          主站蜘蛛池模板: 张北县| 哈尔滨市| 札达县| 株洲县| 敖汉旗| 波密县| 新巴尔虎左旗| 三穗县| 崇文区| 南丰县| 海南省| 通州区| 叶城县| 固安县| 定州市| 天柱县| 府谷县| 渭源县| 吉木乃县| 林芝县| 贞丰县| 新竹县| 三亚市| 滁州市| 昌吉市| 自治县| 东安县| 伊金霍洛旗| 张家川| 通城县| 丰原市| 乐清市| 昌宁县| 商都县| 莱西市| 六枝特区| 苏尼特左旗| 宜丰县| 蓬莱市| 文昌市| 西贡区|