HashMap两种遍历方式的深入研究

本文通过实验对比了HashMap使用entrySet和keySet两种遍历方式的性能,结果显示两者时间消耗相近,性能差异不大。深入分析了HashMap迭代器源码及get方法实现,建议根据实际需求选择遍历方式。

转自:http://swiftlet.net/archives/1259

HashMap的遍历有两种方式,如下所示:
第一种利用entrySet的方式:

上面的方式可以变化为for循环的形式:

第二种利用keySet的方式:

上面的方式也可以变化为for循环的形式:

这两种方式那种效率高呢?可以从下面的试验可以看出来:

结论:
经过运行多次,我发现两者的运行时间相差不多,而且没有明确显示出那种变量方式更快一些。有的人可能会觉得第一种变量方式会快一些,因为他们觉得:keySet方式其实是遍历了2次,一次是转为iterator,一次就从HashMap中取出key所对应的value,而entry方式只遍历了一次,把key和value都放到了entry中,所以entry方式更快一些。
但是我觉得这种分析的方式比较主观,我们更应该从源码的角度去分析。首先看一下迭代器的源码:
keySet的迭代器:

entrySet的迭代器:

从上面我们可以看到只是返回值不同而已,父类相同,所以性能相差不多。下面我们再看一下get方法的源码:

 

 

从上面的源码发现get的时间复杂度取决于for循环循环次数,即hash算法。所以两种性能差别不大。从上面的分析来看,我们得到最终的结论:
(1)HashMap的循环,如果既需要key也需要value,直接用

即可,foreach简洁易懂。
(2)如果只是遍历key而无需value的话,可以直接用

 

转载于:https://www.cnblogs.com/hadoop-dev/p/6255466.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值