前言
大家好,大家在项目中经常使用到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集合元素输出结果如下:
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集合元素输出结果如下:
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集合元素输出结果如下:
Map.values()
第四种通过Map.values()的方式遍历Map元素,通过Map.values()遍历所有的value,但不能遍历key。测试代码如下:
for (String v : map.values()) { System.out.println("value= " + v); }
Map.values()遍历Map集合元素value值输出结果如下:
通过以上四种方式遍历Map,第四种方式只能获取到Map的value值,前三种都能获取到key和value。大家熟悉了集中遍历方式,下面进行性能测试。
性能测试
以上介绍了4种Map的遍历方式,下面针对4种遍历的方式进行性能测试。看那种遍历性能比较好、效率高。 100条数据执行时间如下:
1000条数据执行时间如下:
10000条数据执行时间如下:
100000条数据执行时间如下:
1000000 条数据执行时间如下:
10000000 条数据执行时间如下:
数据表格统计如下:
执行方式 | 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集合的遍历方式及其效率情况