总结Map集合的遍历方式及其效率情况

简介: 总结Map集合的遍历方式及其效率情况

前言


  大家好,大家在项目中经常使用到Map集合来封装数据,正好近期也在使用,当遍历Map中的数据的时候,他们的效率是怎么样的呢,近期就进行了一下介绍。


Map


  Map供了一个更通用的元素存储方法,Map接口存储一组键值对象,提供key(键)到value(值)的映射。Map 集合中的每一个元素都包含一个键对象和一个值对象。


初始化数据


  首先为了便于介绍Map的遍历和他们的执行效率,本次测试先初始化一部分数据,本次将基于四种方式针对Map集合进行遍历,并测试他们的效率。四种方式分别是:Map.keySet()、map.entrySet()、Iterator迭代器、map.values()这四种方式进行。介绍方式,再进行性能比较。构造的测试数据如下:


Map<String, String> map = new HashMap<String, String>();
map.put("1", "掘金");
map.put("2", "代码不止");
map.put("3", "掘金不停");


Map.keySet()


  第一种介绍基于Map.keySet遍历key和value的方式遍历Map中的元素。


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

  

Map.keySet()遍历Map集合元素输出结果如下:


image.png


Iterator迭代器


  第二种方式采用Iterator迭代器使用iterator迭代器遍历key和value。测试代码如下:

Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();
while (it.hasNext()) {
    Map.Entry<String, String> entry = it.next();
    System.out.println("通过Map.entrySet.key= " + entry.getKey() + " and value= " + entry.getValue());
}

  Iterator迭代器遍历Map集合元素输出结果如下:

image.png


Map.entrySet()


第三种方式采用Map.entrySet遍历key和value的方式。测试代码如下:



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

  

Map.entrySet()遍历Map集合元素输出结果如下:


image.png


Map.values()


  第四种通过Map.values()的方式遍历Map元素,通过Map.values()遍历所有的value,但不能遍历key。测试代码如下:


for (String v : map.values()) {
    System.out.println("value= " + v);
}

  

Map.values()遍历Map集合元素value值输出结果如下:


image.png


通过以上四种方式遍历Map,第四种方式只能获取到Map的value值,前三种都能获取到key和value。大家熟悉了集中遍历方式,下面进行性能测试。


性能测试


以上介绍了4种Map的遍历方式,下面针对4种遍历的方式进行性能测试。看那种遍历性能比较好、效率高。 100条数据执行时间如下:


image.png

1000条数据执行时间如下:

image.png

10000条数据执行时间如下:

image.png


100000条数据执行时间如下:

image.png


1000000 条数据执行时间如下:


image.png


10000000 条数据执行时间如下:


image.png


数据表格统计如下:

执行方式 100条 1000条 10000条 100000条 1000000条 10000000条
Map.keySet() 2ms 10ms 54ms 414ms 5215ms 52741ms
Iterator 2ms 7ms 46ms 417ms 4735ms 48822ms
Map.entrySet() 2ms 11ms 51ms 439ms 4708ms 48186ms
Map.values() 0ms 9ms 41ms 385ms 4696ms 46896ms

  

通过表格中的数量量和所使用的不同方式执行Map遍历所耗时时间的表格可以看出,在数量量小的时候,可以使用Iterator迭代器的方式效率比较高,在数据量多到一定程度之后,使用Map.entrySet()的方式能明显提升执行的效率。当然这些数据只是代码作者测试的时候产生的耗时,可能基于机器等外界条件,会有部分误差,仅供大家参考学习。


结语


  好了,以上就是总结的Map集合的遍历方式及其效率情况


目录
相关文章
|
12天前
|
Dart
Dart之集合详解(List、Set、Map)
Dart之集合详解(List、Set、Map)
14 1
|
17天前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
|
12天前
|
存储 消息中间件 算法
Java中的集合框架详解:List、Set、Map的使用场景
Java中的集合框架详解:List、Set、Map的使用场景
|
1天前
|
JavaScript API
js【最佳实践】遍历数组的八种方法(含数组遍历 API 的对比)for,forEach,for of,map,filter,reduce,every,some
js【最佳实践】遍历数组的八种方法(含数组遍历 API 的对比)for,forEach,for of,map,filter,reduce,every,some
9 1
|
13天前
|
缓存 Java 测试技术
探讨Java中遍历Map集合的最快方式
探讨Java中遍历Map集合的最快方式
12 1
Map集合的有序遍历,解决方法多看一下别人的资料
Map集合的有序遍历,解决方法多看一下别人的资料
|
9天前
|
前端开发
Request获取Map集合,提取username后面的值方法,post和get提取集合的方法
Request获取Map集合,提取username后面的值方法,post和get提取集合的方法
|
10天前
|
存储 API Kotlin
Kotlin中的Map集合
Kotlin中的Map集合
24 0
|
17天前
|
Java
Java集合之map 集合使用
Java集合之map 集合使用
10 0
|
17天前
遍历Map的四种方法之map.entry详解
遍历Map的四种方法之map.entry详解