今天被问到一个问题,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在链式结构较快,等过段时间空了验证完了,我会来给大家答案。