迭代器是一种设计模式,它是一个对象,它能够遍历并选择序列中的对象,而开发人员不须要了解该序列的底层结构。迭代器一般被称为“轻量级”对象,由于建立它的代价小。java
Java中的Iterator功能比较简单,而且只能单向移动:算法
(1) 使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。注意:iterator()方法是java.lang.Iterable接口,被Collection继承。设计模式
(2) 使用next()得到序列中的下一个元素。数组
(3) 使用hasNext()检查序列中是否还有元素。数据结构
(4) 使用remove()将迭代器新返回的元素删除。spa
Iterator是Java迭代器最简单的实现,为List设计的ListIterator具备更多的功能,它能够从两个方向遍历List,也能够从List中插入和删除元素。.net
1 迭代器应用: 2 list l = new ArrayList(); 3 l.add("aa"); 4 l.add("bb"); 5 l.add("cc"); 6 for (Iterator iter = l.iterator(); iter.hasNext();) { 7 String str = (String)iter.next(); 8 System.out.println(str); 9 } 10 /*迭代器用于while循环 11 Iterator iter = l.iterator(); 12 while(iter.hasNext()){ 13 String str = (String) iter.next(); 14 System.out.println(str); 15 } 16 */
1.Iterator设计
Java提供一个专门的迭代器<<interface>>Iterator,咱们能够对某个序列实现该interface,来提供标准的Java迭代器。Iterator接口实现后的功能是“使用”一个迭代器.code
2.Iterable对象
Java中还提供了一个Iterable接口,Iterable接口实现后的功能是“返回”一个迭代器,咱们经常使用的实现了该接口的子接口有: Collection<E>, Deque<E>, List<E>, Queue<E>, Set<E> 等.该接口的iterator()方法返回一个标准的Iterator实现。实现这个接口容许对象成为 Foreach 语句的目标。就能够经过Foreach语法遍历你的底层序列。
Iterable接口包含一个可以产生Iterator的iterator()方法,而且Iterable接口被foreach用来在序列中移动。所以若是建立了任何实现Iterable接口的类,均可以将它用于foreach语句中。
3 Iterator与泛型搭配
Iterator对集合类中的任何一个实现类,均可以返回这样一个Iterator对象。能够适用于任何一个类。
由于集合类(List和Set等)能够装入的对象的类型是不肯定的,从集合中取出时都是Object类型,用时都须要进行强制转化,这样会很麻烦,用上泛型,就是提早告诉集合肯定要装入集合的类型,这样就能够直接使用而不用显示类型转换.很是方便.
4.foreach和Iterator的关系
for each是jdk5.0新增长的一个循环结构,能够用来处理集合中的每一个元素而不用考虑集合定下标。
格式以下
for(variable:collection){ statement; }
定义一个变量用于暂存集合中的每个元素,并执行相应的语句(块)。collection必须是一个数组或者是一个实现了lterable接口的类对象。
能够看出,使用for each循环语句的优点在于更加简洁,更不容易出错,没必要关心下标的起始值和终止值。
forEach不是关键字,关键字仍是for,语句是由iterator实现的,他们最大的不一样之处就在于remove()方法上。
通常调用删除和添加方法都是具体集合的方法,例如:
List list = new ArrayList(); list.add(...); list.remove(...);
可是,若是在循环的过程当中调用集合的remove()方法,就会致使循环出错,由于循环过程当中list.size()的大小变化了,就致使了错误。 因此,若是想在循环语句中删除集合中的某个元素,就要用迭代器iterator的remove()方法,由于它的remove()方法不只会删除元素,还会维护一个标志,用来记录目前是否是可删除状态,例如,你不能连续两次调用它的remove()方法,调用以前至少有一次next()方法的调用。
forEach就是为了让用iterator循环访问的形式简单,写起来更方便。固然功能不太全,因此但若有删除操做,仍是要用它原来的形式。
4 使用for循环与使用迭代器iterator的对比
效率上的各有有事
采用ArrayList对随机访问比较快,而for循环中的get()方法,采用的便是随机访问的方法,所以在ArrayList里,for循环较快
采用LinkedList则是顺序访问比较快,iterator中的next()方法,采用的便是顺序访问的方法,所以在LinkedList里,使用iterator较快
从数据结构角度分析,for循环适合访问顺序结构,能够根据下标快速获取指定元素.而Iterator 适合访问链式结构,由于迭代器是经过next()和Pre()来定位的.能够访问没有顺序的集合.