1、最常见的并且在大多数情况下也是最可取的遍历方式
/**
* 最常见也是大多数情况下用的最多的,一般在键值对都需要使用
*/
Map <String,String>map = new HashMap<String,String>();
map.put("aa", "11");
map.put("bb", "22");
for(Map.Entry<String, String> entry : map.entrySet()){
String mapKey = entry.getKey();
String mapValue = entry.getValue();
System.out.println(mapKey+":"+mapValue);
}
2、for-each循环中遍历keys或values
- 通过keySet或values来实现遍历,而不是用entrySet
- 比entrySet遍历在性能上稍好(快了10%),而且代码更加干净
Iterator<Entry<String, String>> entries = map.entrySet().iterator();
while(entries.hasNext()){
Entry<String, String> entry = entries.next();
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key+":"+value);
}
3、使用Iterator遍历
- 可以在遍历时调用iterator.remove()来删除entries,另两个方法则不能(迭代器特性)
- 性能方面看,该方法类同于for-each遍历(即方法二)的性能
(1)使用泛型
(2)不使用泛型
Map <String,String>map = new HashMap<String,String>();
map.put("aa", "11");
map.put("bb", "22");
//key
for(String key : map.keySet()){
System.out.println(key);
}
//value
for(String value : map.values()){
System.out.println(value);
}
4、通过键找值遍历(效率低)
- 它这种方式相当慢且无效率,因为本身从键取值是耗时的操作;
- 从键取值是耗时的操作 1、相比,在不同的Map实现中该方法慢了20%~200%
- FindBugs 会警告这种低效率遍历
for(String key : map.keySet()){
String value = map.get(key);
System.out.println(key+":"+value);
}