Java 中 Map 的 16 种遍历方式 及 性能对比

java 复制代码
for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
}

Iterator<Map.Entry<Integer, Integer>> entries = map.entrySet().iterator();
while (entries.hasNext()) {
    entries.next();
}

map.forEach((key, value) -> {
});

map.entrySet().stream().forEach((entry) -> {
});

map.entrySet().parallelStream().forEach((entry) -> {
});
java 复制代码
for (Integer key : map.keySet()) {
}

Iterator<Integer> iteratorKeySet = map.keySet().iterator();
while (iteratorKeySet.hasNext()) {
    iteratorKeySet.next();
}

map.keySet().forEach((key) -> {
});

map.keySet().stream().forEach((entry) -> {
});

map.keySet().parallelStream().forEach((entry) -> {
});
java 复制代码
for (Integer value : map.values()) {
}

Iterator<Integer> iteratorValues = map.values().iterator();
while (iteratorValues.hasNext()) {
    iteratorValues.next();
}

map.values().forEach((values) -> {
});

map.values().stream().forEach((entry) -> {
});

map.values().parallelStream().forEach((value) -> {
});

for (Integer key : map.keySet()) {
    map.get(key);
}

性能比较

java 复制代码
每种循环各遍历50000000次 total cost time = 3996 ms

map.entrySet()                           : 348 ms, 8.71%
map.entrySet().iterator()                : 356 ms, 8.91%
map.forEach                              : 235 ms, 5.88%
map.entrySet().stream().forEach          : 227 ms, 5.68%
map.entrySet().parallelStream().forEach  : 116 ms, 2.90%
map.keySet()                             : 294 ms, 7.36%
map.keySet().iterator()                  : 301 ms, 7.53%
map.keySet().forEach                     : 226 ms, 5.66%
map.keySet().stream().forEach            : 227 ms, 5.68%
map.keySet().parallelStream().forEach    : 126 ms, 3.15%
map.values()                             : 301 ms, 7.53%
map.values().iterator()                  : 303 ms, 7.58%
map.values().forEach                     : 219 ms, 5.48%
map.values().stream().forEach            : 228 ms, 5.71%
map.values().parallelStream().forEach    : 122 ms, 3.05%
map.keySet() → map.get(key)              : 358 ms, 8.96%
相关推荐
Seven971 小时前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德12 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆14 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌16 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊17 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang18 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
IVEN_18 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang19 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮19 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
Java水解19 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端