1. 程式人生 > >(2)map 遍歷的四種方式

(2)map 遍歷的四種方式

首先建立一個map,放入10000條資料

Map<Integer,String> map=new HashMap<Integer,String>();
for(int i=0;i<10000;i++){
    map.put(i,"value"+i);
}
(1)第一種,通過entry獲得key和value,注意:for-each迴圈在Java 5中被引入所以該方法只能應用於java 5或更高的版本中。 如果你遍歷的是一個空的map物件,for-each迴圈將丟擲NullPointerException,因此在遍歷前你總是應該檢查空引用

for(Map.Entry<Integer,String> entry:map.entrySet()){
System.out.println(entry.getKey()+"-------------"+entry.getValue());
}

(2)第二種,通過key獲得value

for(Integer key:map.keySet()){
    String value = map.get(key);
    System.out.println(key+"----------"+value);
}

(3)第三種key ,value分開獲取(如果只需要map中的鍵或者值比較適用)

for(String value:map.values()){
    System.out.println("value"+value);
}
for(Integer key:map.keySet()){
    System.out.println("key"+key);
}

(4)使用Iterator遍歷                                                                                                                                                                       你也可以在keySet和values上應用同樣的方法。該種方式看起來冗餘卻有其優點所在。首先,在老版本java中這是惟一遍歷map的方式。另一個好處是,你可以在遍歷時呼叫iterator.remove()來刪除entries,另兩個方法則不能。根據javadoc的說明,如果在for-each遍歷中嘗試使用此方法,結果是不可預測的。從效能方面看,該方法類同於for-each遍歷(即方法二)的效能

Iterator<Map.Entry<Integer, String>> entries = map.entrySet().iterator();
while (entries.hasNext())
{
    Map.Entry<Integer, String> entry = entries.next();
    System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
}