Java迭代器 & for循环的区别

1、Iterator接口:

Iterator接口包含三个方法:hasNext,next,remove
在这里插入图片描述

Iterator常用于对集合进行 一边遍历一边修改 的操作

注意:当Iterator迭代访问Collection集合中元素时,Collection的元素不能改变(多个线程的修改),只有通过Iterator的remove()方法删除上一次next()方法返回集合才可以。

2、迭代器和for循环的效率比较

for循环调用get()方法,是随机访问;
iterator调用next()方法,是顺序访问;

举例说明:
若使用ArrayList,对随机访问比较快,因此适合用for循环较快;
若使用LinkedList,对顺序访问比较快,因此适合用iterator迭代访问;

1)从数据结构角度分析,for循环适合访问顺序结构,可以根据下标快速获取指定元素.而Iterator 适合访问链式结构,因为迭代器是通过next()和Pre()来定位的.可以访问没有顺序的集合.

2)而使用 Iterator 的好处在于可以使用相同方式去遍历集合中元素,不用考虑集合类的内部实现(只要它实现了 java.lang.Iterable 接口)。如果使用 Iterator 来遍历集合中元素,一旦不再使用 List 转而使用 Set 来组织数据,那遍历元素的代码不用做任何修改;如果使用 for 来遍历,那所有遍历此集合的算法都得做相应调整,因为List有序,Set无序,结构不同,他们的访问算法也不一样.

3)用for-each处理集合中的每个元素而不用考虑集合定下标,就是为了让用Iterator简单。但是删除的时候,区别就是在remove,循环中调用集合remove会导致原集合变化导致错误,而应该用迭代器的remove方法。

原文链接:https://blog.youkuaiyun.com/Jae_Wang/article/details/80526216

3、遍历ArrayList & LinkedList

实验证明,遍历一个ArrayList 和 一个LinkedList,ArrayList 的遍历速度更快,可能因为底层实现是数组。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值