在java中全部的map都實現了Map接口,所以全部的Map(如HashMap, TreeMap, LinkedHashMap, Hashtable等)均可以用如下的方式去遍歷。java
方法一:在for循環中使用entries實現Map的遍歷(最經常使用的):性能
/**
* 最多見也是大多數狀況下用的最多的,通常在鍵值對都須要使用
*/
Map <String,String>map = new HashMap<String,String>();
map.put("one", "我是第一名");
for(Map.Entry<String, String> entry : map.entrySet()){
String mapKey = entry.getKey();
String mapValue = entry.getValue();
System.out.println(mapKey+":"+mapValue);
}指針
方法二:在for循環中遍歷key或者values,只須要map中的key或者value時使用,在性能上比使用entrySet較好;接口
Map <String,String>map = new HashMap<String,String>();
map.put("one", "我是第一名");
//key
for(String key : map.keySet()){
System.out.println(key);
}
//value
for(String value : map.values()){
System.out.println(value);
}get
方法三:經過Iterator遍歷(加強for循環原理也是Iterator);it
Iterator<Entry<String, String>> entries = map.entrySet().iterator();
while(entries.hasNext()){for循環
//先next在獲取,不然會空指針
Entry<String, String> entry = entries.next();
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key+":"+value);
}table
方法四:經過鍵找值遍歷,這種方式的效率比較低,由於自己從鍵取值是耗時的操做;效率
for(String key : map.keySet()){ String value = map.get(key); System.out.println(key+":"+value); }