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在链式结构较快,等过段时间空了验证完了,我会来给大家答案。
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在链式结构较快,等过段时间空了验证完了,我会来给大家答案。
相关文章推荐
- Google Chrome OS 初体验
- WPF 3D初体验
- xml学习初体验
- Struts 2 框架初体验,被HelloWorld卡住了
- Spring MVC 初体验(二)
- Office Live Workspace 初体验[转]
- Photosynth初体验,可以取代被WALL的Picasa?
- Windows Embedded CE 6.0开发初体验(一)Windows CE概述
- ASP.NET MVC 3 Beta初体验之实用的WebMail【附示例下载】
- 黄聪:1.LinQ初体验 简单的示例(原创)
- 来自黑莓的魅力,北京移动BlackBerr BIS业务初体验
- HTC Desire HD (G10)初体验
- Ubuntu11.04安装初体验(图)
- Kinect for Windows SDK开发初体验(一)环境配置
- csdn新版博客初体验
- 马宁的Windows Phone 7.1初体验(二)——Push Notification
- 初体验
- APNs初体验
- MongoDB学习笔记——初体验
- zeroMQ初体验-18.应答模式进阶(四)-定制路由3