Map遍历优化:entrySet比keySet更高效
时间:2026-01-28 10:27:46 461浏览 收藏
偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《Map遍历优化:用entrySet代替keySet更高效》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

遍历 Map 时若需同时访问键与值,应直接使用 `entrySet()` 迭代,避免通过 `keySet()` 遍历后再调用 `get()` 查找值——后者会带来冗余哈希查找开销,降低性能且触发 SonarQube 等工具的代码异味警告(RSPEC-2864)。
在 Java 中,Map 接口提供了两种主流遍历方式:keySet() 和 entrySet()。表面上看,二者都能完成遍历任务;但从性能和语义清晰度角度,当循环体内需要访问键对应的值时,entrySet() 是更优、更推荐的选择。
为什么 keySet + get 是低效的?
以原始代码为例:
for (String accounts : shiftDatesMap.keySet()) {
Set<String> shiftDates = shiftDatesMap.get(accounts); // ❌ 每次都触发一次哈希查找
// … 后续逻辑
}尽管 HashMap.get() 平均时间复杂度为 O(1),但它仍需重新计算哈希值、定位桶位、处理可能的哈希冲突(如链表或红黑树查找)。在 keySet() 迭代中,JVM 已经在内部遍历了所有 Node(即键值对),却舍近求远地“丢弃”了现成的值,再额外发起一次查找——这属于典型的重复工作(redundant computation)。
正确做法:用 entrySet 直接解构键值对
改写为 entrySet() 遍历后,可一次性获取键与值,零成本访问:
for (Map.Entry<String, Set<String>> entry : shiftDatesMap.entrySet()) {
String accounts = entry.getKey(); // ✅ 直接获取键
Set<String> shiftDates = entry.getValue(); // ✅ 直接获取值,无额外开销
// 后续逻辑可直接使用 accounts 和 shiftDates
}该方式不仅提升性能(尤其在大数据量或高频调用场景下),还增强了代码可读性与意图表达:明确表明“我需要处理每一个键值对”,而非“我先取所有键,再逐个查值”。
实际应用示例(修复原始方法)
将您原方法中的低效循环替换如下:
public Set<Date> getAccountShiftDate(Map<String, Set<String>> shiftDatesMap,
List<Groups> shiftSchedule) {
Set<Date> accountShiftDatesTemplate = new HashSet<>();
// ✅ 使用 entrySet 替代 keySet
for (Map.Entry<String, Set<String>> entry : shiftDatesMap.entrySet()) {
String accounts = entry.getKey();
Set<String> shiftDates = entry.getValue(); // 值已就绪,无需 get()
Optional<Groups> shiftOptional = shiftSchedule.stream()
.filter(g -> StringUtils.equalsIgnoreCase(accounts, g.getLongName()))
.findFirst();
if (shiftOptional.isPresent()) {
// 基于 shiftDates 和 shiftOptional 进行后续业务处理...
// 例如:解析日期、添加到 accountShiftDatesTemplate 等
}
}
return accountShiftDatesTemplate;
}注意事项与补充建议
- ✅ 适用前提:仅当循环内确实需要值(value)或同时需要键与值时,才必须优先选用 entrySet();若仅需键(如做存在性校验),keySet() 仍合理。
- ✅ 泛型安全:务必声明完整泛型类型 Map.Entry
,避免原始类型警告;Java 10+ 可用 var 简化(for (var entry : map.entrySet())),但需确保可读性不受损。 - ⚠️ 并发 Map 注意:ConcurrentHashMap.entrySet() 返回的 Entry 在迭代期间不保证强一致性(可能反映部分更新状态),但这是其设计使然,非本优化范畴问题。
- ? 工具提示意义:SonarQube 的 RSPEC-2864 不仅是性能建议,更是代码质量信号——它提示开发者关注数据结构访问模式是否符合直觉与最佳实践。
总之,entrySet() 是 Map 遍历的“黄金路径”。养成习惯:只要涉及键值协同操作,首选 entrySet() ——简洁、高效、专业。
今天关于《Map遍历优化:entrySet比keySet更高效》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
309 收藏
-
211 收藏
-
409 收藏
-
312 收藏
-
415 收藏
-
410 收藏
-
408 收藏
-
227 收藏
-
101 收藏
-
288 收藏
-
168 收藏
-
415 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习