news 2026/6/26 3:20:30

Java Map 循环:遍历方式与性能对比

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java Map 循环:遍历方式与性能对比

Map 遍历的基础准备

Map<String, String> map = new HashMap<>();
map.put("A", "Apple");
map.put("B", "Banana");
map.put("C", "Cherry");

2. 七种遍历方式详解

2.1 entrySet + for-each(推荐)

最经典、最通用的方式。

for (Map.Entry<String, String> entry : map.entrySet()) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + " -> " + value);
}

优点:同时获取 key 和 value,性能最佳(只遍历一次)
缺点:代码稍长(但可读性好)

2.2 keySet + for-each(不推荐)

只取 key,再通过 key 获取 value。

for (String key : map.keySet()) {
String value = map.get(key);
System.out.println(key + " -> " + value);
}

缺点:需要两次查找(迭代 +get),HashMap 中性能约为 entrySet 的一半。

2.3 只遍历 value

for (String value : map.values()) {
System.out.println(value);
}

适用场景:只需要 value,不需要 key。

2.4 Iterator + entrySet(适合删除操作)

Iterator<Map.Entry<String, String>> iter = map.entrySet().iterator();
while (iter.hasNext()) {
Map.Entry<String, String> entry = iter.next();
if ("B".equals(entry.getKey())) {
iter.remove(); // 安全删除
}
}

优点:遍历过程中可以安全删除元素。

2.5 forEach (Java 8+ Lambda)

map.forEach((key, value) -> System.out.println(key + " -> " + value));

优点:代码简洁优雅
缺点:不能修改外部非 final 变量(需要变通),不支持break/return提前终止(必须抛出异常)。

2.6 Stream API(函数式处理)

map.entrySet().stream()
.filter(e -> e.getKey().startsWith("A"))
.forEach(e -> System.out.println(e.getKey() + " -> " + e.getValue()));

适用场景:需要链式过滤、映射、聚合等操作。

2.7 仅 JDK 8+ 的 compute / merge 等(函数式计算)

虽然不属于“遍历”,但适用于边遍历边计算新值。

map.replaceAll((key, value) -> value.toUpperCase());

3. 性能对比(HashMap 测试)

方式100万条目耗时(ms)推荐指数
entrySet for-each32⭐⭐⭐⭐⭐
Iterator + entrySet33⭐⭐⭐⭐
forEach (Lambda)34⭐⭐⭐⭐⭐
Stream API38⭐⭐⭐⭐
keySet + get67⭐⭐

测试环境:JDK 17, HashMap<String,String>, 100万条目,平均取三次。


4. 并发场景下的遍历

4.1 ConcurrentHashMap

ConcurrentHashMap<String, String> cmap = new ConcurrentHashMap<>();
// 使用与 HashMap 相同的遍历方式,但弱一致性
cmap.forEach((k, v) -> System.out.println(k));

4.2 遍历时修改(避免 ConcurrentModificationException)

  • 普通 HashMap:只能用Iterator.remove()
  • ConcurrentHashMap:支持安全遍历,但无法保证立即看到最新数据
// 错误示范(会抛异常)
for (String key : map.keySet()) {
if (condition) map.remove(key);
}
// 正确方式:Iterator 删除
Iterator<Map.Entry<String,String>> it = map.entrySet().iterator();
while(it.hasNext()){
if(condition) it.remove();
}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 3:19:15

从零构建智能寻迹小车:STM32核心的PID控制与硬件设计全解析

1. 项目概述&#xff1a;从玩具到工业应用的智能移动平台寻迹小车&#xff0c;听起来像是个简单的电子玩具&#xff0c;但当你真正深入进去&#xff0c;会发现它其实是一个微缩版的智能移动机器人平台。它要解决的核心问题&#xff0c;就是让一个无人驾驶的轮式小车&#xff0c…

作者头像 李华
网站建设 2026/6/26 3:18:08

修复Codex++安装后历史对话消失的问题

其实是设置问题&#xff0c;这个地方点一下就行。只不过这个问题连GPT都不知道&#xff0c;差点让我去动原始缓存。故记录在这里

作者头像 李华
网站建设 2026/6/26 3:17:25

第2章:Docker 单机极速部署与目录结构解析

1. 项目背景 小张是公司的初级开发工程师&#xff0c;工位旁边的测试老周天天催他&#xff1a;"你说的那个 Dify 智能客服&#xff0c;啥时候能让我测&#xff1f;"小张看了看手边的电脑——一台 16G 内存的 Windows 笔记本&#xff0c;心里有点虚&#xff1a;“这个…

作者头像 李华
网站建设 2026/6/26 3:17:06

用ANTLR实现表达式词法和语法分析器

旧方案&#xff1a;正则表达式词法分析 在上一代平台采用正则表达式来进行词法分析&#xff0c;词法分析器代码如下&#xff1a; /// <summary> /// 文本格式表达式语法分析器 /// </summary> /// <remarks> /// ${XXX} - 参变量 /// XXX - 参数 /// </…

作者头像 李华
网站建设 2026/6/26 3:17:04

Linux学习笔记3:进程和进程间通信

1. 引言 今日继续&#xff1a;进程管理与进程间通信&#xff08;IPC&#xff09;。理解进程如何创建、调度以及彼此之间如何传递数据&#xff0c;是编写高效 Shell 脚本和系统编程的基础。 2. 进程是什么 简单说&#xff0c;程序是存放在磁盘上的静态文件&#xff0c;进程是…

作者头像 李华
网站建设 2026/6/26 3:15:48

免费获取专业级字体:Montserrat完整使用终极指南

免费获取专业级字体&#xff1a;Montserrat完整使用终极指南 【免费下载链接】Montserrat 项目地址: https://gitcode.com/gh_mirrors/mo/Montserrat 还在为设计项目找不到既专业又好看的字体而烦恼吗&#xff1f;Montserrat字体是设计师们都在悄悄使用的秘密武器——这…

作者头像 李华