Java中遍历Map最推荐用entrySet()同时获取键和值;其次可用keySet()遍历键再get值,或values()遍历值;Java 8+还可使用forEach+Lambda简化代码。
Java 中的 Map 是存储键值对(key-value)的核心集合类型,不能直接用 for-each 遍历整个 Map,但有几种清晰、常用、适合新手的遍历方式,掌握这几种就足够应付大多数场景。
这是最常用、效率高、语义清晰的方式。把 Map 转成 Set,每项是一个“键值对对象”,可同时拿到 key 和 value。
示例:
Mapmap = new HashMap<>(); map.put("苹果", 5); map.put("香蕉", 3); for (Map.Entry entry : map.entrySet()) { String key = entry.getKey(); Integer value = entry.getValue(); System.out.println(key + " → " + value); } // 输出:苹果 → 5,香蕉 → 3 (顺序不保证)
LinkedHashMap(按插入顺序)或 TreeMap(按键排序)如果只需要 key,或偶尔才用到 value,可以用 keySet() 获取所有键的集合。
for (String key : map.keySet()) {
Integer value = map.get(key); // 注意:get 可能返回 null(若 value 允许为 null)
System.out.println(key + " → " + value);
}
get() 是一次哈希查找,性能略低于 entrySet(小数据量无感)get(key) == null 不能直接判断 key 不存在,要用 containsKey()
当只对值做操作(比如求和、找最大值),用 values() 最简洁。
int sum = 0;
for (Integer v : map.values()) {
sum += v;
}
System.out.println("总数量:" + sum);
语法糖,本质还是基于 entrySet,但更紧凑,适合简单逻辑。
map.forEach((key, value) ->
System.out.println(key + " → " + value)
);
break 或 continue,复杂逻辑建议用传统 for 循环基本上就这些。新手记住 entrySet 是主力,keySet 和 values 各有适用场景,Lambda 是加分项。不用死记,写几次就自然了。