Java中遍历Map最推荐用entrySet()同时获取键和值;其次可用keySet()遍历键再get值,或values()遍历值;Java 8+还可使用forEach+Lambda简化代码。

Java 中的 Map 是存储键值对(key-value)的核心集合类型,不能直接用 for-each 遍历整个 Map,但有几种清晰、常用、适合新手的遍历方式,掌握这几种就足够应付大多数场景。
用 entrySet() 遍历键和值(最推荐)
这是最常用、效率高、语义清晰的方式。把 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(顺序不保证)
- ✅ 推荐新手优先掌握,逻辑直白,不易出错
- ✅ 一次循环拿到 key 和 value,避免重复查表
- ⚠️ 注意:HashMap 不保证顺序;如需有序,用
LinkedHashMap(按插入顺序)或TreeMap(按键排序)
只遍历 key,再通过 key 取 value
如果只需要 key,或偶尔才用到 value,可以用 keySet() 获取所有键的集合。
立即学习“Java免费学习笔记(深入)”;
for (String key : map.keySet()) {
Integer value = map.get(key); // 注意:get 可能返回 null(若 value 允许为 null)
System.out.println(key + " → " + value);
}
- ✅ 适合“先检查 key 是否存在”或“批量处理 key”的场景
- ⚠️ 每次调用
get()是一次哈希查找,性能略低于 entrySet(小数据量无感) - ⚠️ 若 value 可为 null,
get(key) == null不能直接判断 key 不存在,要用containsKey()
只遍历 value(不关心 key)
当只对值做操作(比如求和、找最大值),用 values() 最简洁。
int sum = 0;
for (Integer v : map.values()) {
sum += v;
}
System.out.println("总数量:" + sum);
- ✅ 代码最短,意图明确
- ❌ 无法知道当前 value 对应哪个 key
- ⚠️ 返回的是 Collection,不是 Set —— 允许重复值
用 forEach + Lambda(Java 8+,简洁写法)
语法糖,本质还是基于 entrySet,但更紧凑,适合简单逻辑。
map.forEach((key, value) ->
System.out.println(key + " → " + value)
);
- ✅ 行数少,适合打印、日志、简单转换
- ⚠️ 不能在 lambda 里用
break或continue,复杂逻辑建议用传统 for 循环 - ⚠️ 如果要修改 map(如 remove),必须用迭代器方式,否则抛 ConcurrentModificationException
基本上就这些。新手记住 entrySet 是主力,keySet 和 values 各有适用场景,Lambda 是加分项。不用死记,写几次就自然了。










