隨筆 - 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學習
          主站蜘蛛池模板: 栖霞市| 新沂市| 那曲县| 玉山县| 宝山区| 龙陵县| 三门县| 怀柔区| 临江市| 永顺县| 开封市| 广南县| 武定县| 册亨县| 邮箱| 寿阳县| 石屏县| 鄂州市| 台前县| 磐安县| 武义县| 喀喇| 古浪县| 拉萨市| 汝阳县| 竹北市| 兴文县| 兴隆县| 乃东县| 南京市| 宾川县| 嵊州市| 梓潼县| 东海县| 左权县| 准格尔旗| 竹山县| 昂仁县| 景宁| 和静县| 巨鹿县|