摘自参考文献How to Iterate Over a Map in Java:
在 Java 中有几种迭代 Map 的方法。让我们回顾一下最常见的方法并回顾它们的优缺点。由于 Java 中的所有地图都实现了 Map 接口,因此以下技术适用于任何地图实现(HashMap、TreeMap、LinkedHashMap、Hashtable 等)
方法 #1:使用 For-Each 循环迭代条目。
这是最常用的方法,在大多数情况下更可取。如果循环中同时需要映射键和值,则应使用它。
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
}
请注意,Java 5 中引入了 For-Each 循环,因此此方法仅适用于较新版本的语言。如果您尝试迭代一个为空的映射,For-Each 循环也会抛出 NullPointerException,因此在迭代之前您应该始终检查空引用。
方法 #2:使用 For-Each 循环迭代键或值。
如果您只需要映射中的键或值,则可以迭代 keySet 或值而不是 entrySet。
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
// Iterating over keys only
for (Integer key : map.keySet()) {
System.out.println("Key = " + key);
}
// Iterating over values only
for (Integer value : map.values()) {
System.out.println("Value = " + value);
}
与entrySet 迭代相比,此方法具有轻微的性能优势(大约快 10%)并且更干净。
方法#3:使用迭代器进行迭代。
使用泛型:
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
Iterator<Map.Entry<Integer, Integer>> entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry<Integer, Integer> entry = entries.next();
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
}
没有泛型:
Map map = new HashMap();
Iterator entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry entry = (Map.Entry) entries.next();
Integer key = (Integer)entry.getKey();
Integer value = (Integer)entry.getValue();
System.out.println("Key = " + key + ", Value = " + value);
}
您也可以使用相同的技术来迭代 keySet 或值。
这种方法可能看起来多余,但它有其自身的优势。首先,它是在旧版 Java 中迭代地图的唯一方法。另一个重要特性是它是唯一允许您在迭代期间通过调用iterator.remove() 从映射中删除条目的方法。如果您尝试在 For-Each 迭代期间执行此操作,您将根据Javadoc 获得“不可预测的结果”。
从性能的角度来看,这种方法等同于 For-Each 迭代。
方法#4:遍历键并搜索值(低效)。
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
for (Integer key : map.keySet()) {
Integer value = map.get(key);
System.out.println("Key = " + key + ", Value = " + value);
}
这可能看起来像是方法 #1 的更清洁的替代方案,但实际上它非常缓慢且效率低下,因为通过键获取值可能很耗时(在不同的 Map 实现中,此方法比 20%-200% 慢方法#1)。如果您安装了 FindBugs,它会检测到这一点并警告您迭代效率低下。应该避免这种方法。
结论:
如果您只需要地图中的键或值,请使用方法 #2。如果您被旧版本的 Java(少于 5 个)卡住或计划在迭代期间删除条目,则必须使用方法 #3。否则使用方法#1。