java集合中迭代器的实现

本文深入探讨了Java中Iterator接口的实现与用途,解释了Iterator如何在集合类如ArrayList中实现遍历操作,同时对比了for循环和foreach循环在集合遍历中的应用与效率。通过分析ArrayList内部类的实现细节,包括hasNext(), next(), remove()等方法,揭示了Iterator的工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文转自:https://blog.youkuaiyun.com/qq_37611061/article/details/80143475

iteraotr与for循环foreach的比较:
https://blog.youkuaiyun.com/zxq1138634642/article/details/8092327?utm_source=blogxgwz0

概要:collection(set和list的父接口)中实现了Iteraor接口

问题一:那Iterator是为什么存在?其实呢,在java中的许多容器中,他们的都需要遍历这个操作,所以能就定义了这个Iterator这个接口还实现多态,减少代码的耦合。

问题二:通常集合实现遍历是使用如下的方法:以ArrayList为例

Iterator itr=ArrayList.lterator;//ArrayList中的iterator方法实际上返回的就是一个Iterator实现类的对象,这个实现类中在集合中定义,作为集合类的内部类

while(itr.hasnext()){

system.in.println(itr.next());

}

问题三:集合中有关于迭代器实现内部类是怎么样定义的呢,这个内部类中有三个方法:hasnext (),next(),remove();具体定义如下:

 public boolean hasNext()
{
return cursor != size;//当cursor不等于size时,表示仍有索引元素
}

 public E next() //返回下一个元素
{
checkForComodification();
int i = cursor;
if (i >= size)
throw new NoSuchElementException();
Object[] elementData = ArrayList.this.elementData;
if (i >= elementData.length)
throw new ConcurrentModificationException();
cursor = i + 1;
return (E) elementData[lastRet = i];
}

 final void checkForComodification()
{
if (modCount != expectedModCount)
throw new ConcurrentModificationException();
}


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值