ArrayList 迭代器模式

在面试中,迭代器被问到了很多次,今天来总结一下。

从一个例子说起。

public static void main(String args[]){
List list=new ArrayList();

list.add(2);
list.add(5);
list.add(7);

Iterator Itr=list.iterator();
while(Itr.hasNext()){
System.out.println(Itr.next());
}
}


上面的例子很简单,但说明了迭代器最基本的结构:
[b]1. 得到迭代器;
2. 判断是否有元素;
3. 获取元素。
[/b]
现在到源码里去看它们是怎样实现的。


public Iterator<E> iterator() {
return new Itr();
}


其实它里面有一个内部类的,再看这个类的成员有哪些。


// 初始值为0,这个与C语言不一样,C是不确定的值
int cursor; // index of next element to return
int lastRet = -1; // index of last element returned; -1 if no such
int expectedModCount = modCount;


下面是hasNext()方法的实现。

public boolean hasNext() {
return cursor != size;
}



简单吧,就是判断当前的指针是否到最后了,我们猜测当前指针的变化应该是在next()方法中实现的。


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];
}


其中的elementData是存储数据的地方,这个在开始就定义了。


private transient Object[] elementData;


这个数组的初始化在什么时候完成的呢?在你new的时候,默认大小是10.


public ArrayList() {
this(10);
}


总体来讲,迭代器还是比较简单的吧。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值