<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 110, comments - 101, trackbacks - 0, articles - 7
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    java map的操作 與 遍歷效率

    Posted on 2011-05-12 21:13 云云 閱讀(10257) 評論(3)  編輯  收藏
    1.聲明一個map: Map map = new HashMap(); 
    2.向map中放值,注意:map是key-value的形式存放的.如:

    map.put(”sa”,”dd”);

    3.從map中取值:String str = map.get(”sa”).toString();結果是:str = ”dd”;

    4.遍歷一個map,從中取得key 和value

    JDK1.
    5

    Map m 
    = new HashMap(); 
    for (Object o : map.keySet()) 
    map.get(o); 
    }


    JDK1.
    4

    Map map 
    = new HashMap() ; 

    Iterator it 
    = map.entrySet().iterator() ; 
    while (it.hasNext()) 

    Map.Entry entry 
    = (Map.Entry) it.next() ; 
    Object key 
    = entry.getKey() ; 
    Object value 
    = entry.getValue() ; 
    }

    遍歷效率對比:
    第一種:

      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 <1000; i ) {

      hashmap.put(
    "" i, "thanks");

      }


      
    long bs = Calendar.getInstance().getTimeInMillis();

      Iterator iterator 
    = hashmap.keySet().iterator();

      
    while (iterator.hasNext()) {

      System.out.print(hashmap.get(iterator.next()));

      }


      System.out.println();

      System.out.println(Calendar.getInstance().getTimeInMillis() 
    - bs);

      listHashMap();

      }


      
    public static void listHashMap() {

      java.util.HashMap hashmap 
    = new java.util.HashMap();

      
    for (int i = 0; i <1000; i ) {

      hashmap.put(
    "" i, "thanks");

      }


      
    long bs = Calendar.getInstance().getTimeInMillis();

      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(Calendar.getInstance().getTimeInMillis() 
    - bs);

      }


      }


      對于keySet其實是遍歷了2次,一次是轉為iterator,一次就從hashmap中取出key所對于的value。而entryset只是遍歷了第一次,他把key和value都放到了entry中,所以就快了。

      注:Hashtable的遍歷方法和以上的差不多
    !

    評論

    # ·1  回復  更多評論   

    2015-09-09 15:55 by ·1
    ABC的風格

    # re: java map的操作 與 遍歷效率  回復  更多評論   

    2015-09-09 15:56 by ·11
    213

    # re: java map的操作 與 遍歷效率  回復  更多評論   

    2015-09-09 15:56 by ·11
    @&#183;1

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 亚洲综合小说另类图片动图| 亚洲一区影音先锋色资源| 亚洲欧美日韩综合俺去了| 99久久久精品免费观看国产| 亚洲熟妇av一区| 99久久99这里只有免费费精品| 亚洲毛片一级带毛片基地| 99视频免费播放| jlzzjlzz亚洲jzjzjz| 青青草免费在线视频| 亚洲色精品VR一区区三区| 精品久久久久久久免费加勒比| 亚洲爆乳精品无码一区二区| 国产免费人成视频在线观看| 美女无遮挡免费视频网站| 免费一看一级毛片全播放| h在线看免费视频网站男男| 亚洲精品无码永久中文字幕| 国产午夜无码精品免费看| 精品亚洲成a人片在线观看| 日韩中文字幕精品免费一区| 亚洲精品乱码久久久久久蜜桃图片| 国产成人高清精品免费软件| 一级成人a免费视频| 色拍自拍亚洲综合图区| 青青青国产在线观看免费| 18禁亚洲深夜福利人口| 久久久久亚洲精品男人的天堂| 久久精品乱子伦免费| 亚洲人成日本在线观看| 免费又黄又硬又爽大片| 野花香高清视频在线观看免费| 91亚洲视频在线观看| 成人亚洲综合天堂| 亚洲精品第一国产综合精品99| 中国好声音第二季免费播放| 亚洲精品第五页中文字幕| 日韩免费一级毛片| 久久99毛片免费观看不卡| 亚洲精品无码人妻无码| 亚洲精品~无码抽插|