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%
相关推荐
YuTaoShao1 小时前
【LeetCode 热题 100】56. 合并区间——排序+遍历
java·算法·leetcode·职场和发展
Code Warrior1 小时前
【每日算法】专题五_位运算
开发语言·c++
程序员张31 小时前
SpringBoot计时一次请求耗时
java·spring boot·后端
沐知全栈开发3 小时前
HTML DOM 访问
开发语言
llwszx4 小时前
深入理解Java锁原理(一):偏向锁的设计原理与性能优化
java·spring··偏向锁
脑袋大大的4 小时前
JavaScript 性能优化实战:减少 DOM 操作引发的重排与重绘
开发语言·javascript·性能优化
云泽野4 小时前
【Java|集合类】list遍历的6种方式
java·python·list
二进制person5 小时前
Java SE--方法的使用
java·开发语言·算法
OneQ6665 小时前
C++讲解---创建日期类
开发语言·c++·算法
IMPYLH6 小时前
Python 的内置函数 reversed
笔记·python