<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

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


    網站導航:
     
    主站蜘蛛池模板: 男女超爽视频免费播放| 久久亚洲精品专区蓝色区| 一级做a爰全过程免费视频毛片| 成年女人免费视频播放体验区| 亚洲剧场午夜在线观看| 日本免费网站视频www区| 亚洲人成免费电影| 日本阿v免费费视频完整版| 国产精品亚洲综合久久| 日本免费人成黄页网观看视频| 国产精品日本亚洲777| 亚洲AⅤ永久无码精品AA| rh男男车车的车车免费网站| 亚洲国产一成人久久精品| 无码人妻丰满熟妇区免费| 亚洲国色天香视频| 日韩免费一级毛片| WWW免费视频在线观看播放| 久久夜色精品国产亚洲AV动态图| **实干一级毛片aa免费| 亚洲最大中文字幕无码网站| 亚洲va中文字幕无码| 免费成人在线电影| 亚洲www77777| 亚洲另类激情综合偷自拍图| 8x网站免费入口在线观看| 亚洲国产精品无码第一区二区三区| 亚洲国产一级在线观看| 久久免费观看国产精品88av| 亚洲一级在线观看| 亚洲午夜精品第一区二区8050| 久久美女网站免费| 亚洲国产精品精华液| 亚洲人成图片小说网站| 97在线观免费视频观看| 成人精品综合免费视频| 亚洲系列国产精品制服丝袜第| 国产精品免费看香蕉| 免费看搞黄视频网站| 亚洲国产成人精品无码区花野真一 | 国产精品无码亚洲一区二区三区|