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

Java 中的 Map 是存储键值对(key-value)的核心集合类型,不能直接用 for-each 遍历整个 Map,但有几种清晰、常用、适合新手的遍历方式,掌握这几种就足够应付大多数场景。
这是最常用、效率高、语义清晰的方式。把 Map 转成 Set<map.entry>></map.entry>,每项是一个“键值对对象”,可同时拿到 key 和 value。
示例:
Map<String, Integer> map = new HashMap<>();
map.put("苹果", 5);
map.put("香蕉", 3);
for (Map.Entry<String, Integer> entry : map.entrySet()) {
String key = entry.getKey();
Integer value = entry.getValue();
System.out.println(key + " → " + value);
}
// 输出:苹果 → 5,香蕉 → 3(顺序不保证)
LinkedHashMap(按插入顺序)或 TreeMap(按键排序)如果只需要 key,或偶尔才用到 value,可以用 keySet() 获取所有键的集合。
立即学习“Java免费学习笔记(深入)”;
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 是加分项。不用死记,写几次就自然了。
以上就是Java Map 怎么用?新手必会的遍历方式的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号