java collection map遍历效率问题

对于collection(list   set)有两种遍历方式,一种for循环遍历 ,一种使用iterator遍历。

对于遍历效率,

arraylist和iterator都是根据下标获取元素,arraylist使用顺序链表存储数据,因此可以直接获取到元素,而iterator获取元素之前还需要校验等;

arraylist使用for循环比使用iterator快


linkedlist使用for循环获取元素时要累加到i才能获取到对应元素,而使用iterator则直接利用指针可以立刻定位到元素;

linkedlist使用iterator比使用for循环要快

以上是网上资料提供。


但是根据本人实测,好像都是iterator速度较快,可能是iterator根据此专门做了优化,具体还有待研究


对于map遍历,一般有三种方式遍历entrySet()  keySet()  values()

对于map遍历 ,一般使用较多的就是entrySet()和keySet()这两种遍历方式

效率上,entrySet()比keySet()要快些。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值