当前位置: 首页 > news >正文

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();
}
http://www.gsyq.cn/news/1590840.html

相关文章:

  • RS485 通信信号线使用共模电感,这几个关键点一定要注意
  • MTX双面解析:从多线程互斥锁到游戏微交易系统设计
  • 研究技术软件工程研究方法的实证研究与案例研究对比
  • Embedding 模型微调实战:从 22% 到 97.9% 的踩坑记录
  • AI 建议加索引后查询仍变慢:从联合索引、回表与分页排序看慢 SQL 排查
  • ESPHome:用配置文件搞定智能硬件开发
  • AI模型访问控制机制与能力评估实践指南
  • 抖音账号与手机号关联验证:合规路径、技术实现与风险规避指南
  • 不用注册就能用的 Web 应用合集
  • 协同线程与协同函数
  • 【题目讲解】 算法系列之定长类滑动窗口解析(上)
  • Kubernetes Pod 完全指南:从入门到实战,轻松掌握容器编排核心
  • V 语言精选资源库
  • 分类评估指标实战指南:从混淆矩阵到业务价值落地
  • 截断流Witt代数的模表示:基于p-特征与高度的简单模分类与构造
  • 抖音无水印视频下载终极指南:3分钟搞定批量下载与智能管理
  • Apple Silicon Mac 电池健康管理终极指南:开源架构设计与实现原理
  • GraalVM原生镜像构建实战:十分钟让你的Java应用启动速度快100倍
  • 2026年国内口碑较好的工艺品设计平台有哪些值得关注
  • VMware虚拟机导出OVF:绕过ovftool命令行的3种GUI替代方案,小白也能10分钟完成合规打包
  • Spring Cloud 服务注册与发现原理
  • CLIP实战避坑指南:图文对齐、零样本迁移与生产部署关键断点
  • 如何快速掌握LangFlow:3步搞定AI应用可视化开发
  • 机器学习模型评估实战:从accuracy陷阱到AUC-ROC与PR曲线深度解析
  • 从脱靶量最小化到杀伤概率最大化:导弹制导新范式解析
  • 3个核心技术突破:Windows系统下LG Ultrafine显示器亮度控制终极方案
  • 注入燃料——Entity Framework Core 与 Code First 实战
  • AI 建议直接升级依赖版本,为什么编译通过后仍可能在运行时 `NoSuchMethodError`
  • 如何正确地“拷贝”一个对象?(深拷贝与浅拷贝)
  • Navicat密码查看工具:终极解决方案帮你找回忘记的数据库密码