您的位置:首页 > 编程语言 > Java开发

lterator的初体验

2017-06-21 21:45 148 查看
今天被问到一个问题,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在链式结构较快,等过段时间空了验证完了,我会来给大家答案。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息