隨筆 - 100  文章 - 50  trackbacks - 0
          <2025年5月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          常用鏈接

          留言簿(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來進(jìn)行遍歷,但兩者的遍歷速度是有差別的,下面請看實(shí)例:

          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() 返回與此項對應(yīng)的鍵
             // entry.getValue() 返回與此項對應(yīng)的值
             System.out.print(entry.getValue());
            }
            System.out.println();
            System.out.println(System.currentTimeMillis() - bg);
          }
          }

          對于keySet其實(shí)是遍歷了2次,一次是轉(zhuǎn)為iterator,一次就從hashmap中取出key所對于的value。而entryset只是遍歷了第一次,他把key和value都放到了entry中,所以就快了。
          posted on 2010-09-06 23:33 fly 閱讀(211) 評論(0)  編輯  收藏 所屬分類: java學(xué)習(xí)
          主站蜘蛛池模板: 广州市| 赣榆县| 青海省| 土默特右旗| 闻喜县| 保康县| 甘谷县| 昌平区| 平乡县| 曲麻莱县| 门头沟区| 石楼县| 华阴市| 诸城市| 洪湖市| 桦甸市| 苗栗县| 衡南县| 莒南县| 敦煌市| 确山县| 镇沅| 五莲县| 横山县| 双鸭山市| 库车县| 华容县| 同心县| 勃利县| 孟津县| 梓潼县| 阿克| 北辰区| 济宁市| 西华县| 德惠市| 柏乡县| 陇西县| 兴义市| 中牟县| 阳曲县|