lterator的初体验

来源:互联网 发布:对人工智能的认识 编辑:程序博客网 时间:2024/05/22 15:02

今天被问到一个问题,lterator和Listlterator之间有什么区别,那我就来说一下自己的看法,查阅了部分资料以及源码的查看如下:

1,首先lterator是Listlterator的父接口。

2,Listlterator只支持list,lterator支持所有实现Iterable接口的,有些人会问list和set为什么可以迭代,因为list和set底层继承collection,而collection则实现了lterable。

我们看一下下面这段代码:

List list=new ArrayList<>();list.add("1");list.add("3");list.add("2");Iterator ite=list.iterator();while(ite.hasNext()){System.out.println(ite.next());}
输出的结果是,1,3,2.lterator中的next()是顺序的访问。

说到lterator我们不得不说一下for each,我一直觉得for循环能完全替代迭代器,事实来说发现这么一个问题,特别是一般形式的for循环

如下:

for(int i = 0 ; i < 10 ; i++){}
问题来了,假如原本有10个元素在一个list中,特定情况下要在循环体中移除一个元素,结果会怎么样,没错,越界,因为我们改变了长度(特殊处理不考虑在内)。

但是对于迭代器来说呢,完全不用担心这个问题,需要的时候调用一个remove()即可。

最后一点还没认证,我会找时间去看一下源码,有朋友介绍说for在顺序结构较快,lterator在链式结构较快,等过段时间空了验证完了,我会来给大家答案。