<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

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲中文字幕久久精品无码APP| 亚洲依依成人亚洲社区| 中国一级特黄的片子免费| 国产高清免费在线| 亚洲xxxx视频| 国产妇乱子伦视频免费| 亚洲精品成人av在线| 中文字幕高清免费不卡视频| 亚洲爽爽一区二区三区| 黄色免费在线观看网址| 日本不卡免费新一二三区| 亚洲午夜福利在线视频| 欧洲精品成人免费视频在线观看 | 国产精品久久久久久久久久免费 | 亚洲av永久无码精品秋霞电影秋| 日本XXX黄区免费看| 亚洲国产精品日韩在线观看| 最近免费中文字幕高清大全 | 国产精品亚洲一区二区三区在线| 国产免费内射又粗又爽密桃视频| 亚洲国产精品13p| 日韩在线一区二区三区免费视频| 亚洲?v女人的天堂在线观看| 羞羞视频在线免费观看| 啊v在线免费观看| 人妻18毛片a级毛片免费看| 亚洲精品无码久久毛片| 七次郎成人免费线路视频| 亚洲日韩在线观看| 久青草视频97国内免费影视| 亚洲色欲色欲www在线丝| a级日本高清免费看| 久久精品国产亚洲香蕉| 最近的中文字幕大全免费8| 亚洲国产精品免费在线观看| 免费三级毛片电影片| 亚洲综合一区国产精品| 日本xxwwxxww在线视频免费| 国产精品亚洲天堂| 国产成人亚洲精品影院| 中文在线日本免费永久18近|