1、介绍
迭代器(Iterator) 迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构。迭代器通常被称为“轻量级”对象,因为创建它的代价小。 Java中的Iterator功能比较简单,并且只能单向移动: (1) 使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。注意:iterator()方法是java.lang.Iterable接口,被Collection继承。 (2) 使用next()获得序列中的下一个元素。 (3) 使用hasNext()检查序列中是否还有元素。 (4) 使用remove()将迭代器新返回的元素删除。 Iterator是Java迭代器最简单的实现,为List设计的ListIterator具有更多的功能,它可以从两个方向遍历List,也可以从List中插入和删除元素
2、例子
List l = new ArrayList();
for (int i = 0; i < l.size(); i++) { // 普通的for循环取出集合中的元素
System.out.print(l.get(i));
}
System.out.println();
for (Object o : l) { // 增强for循环取出集合中的元素
System.out.print(o);
}
System.out.println();
for (Iterator it = l.iterator(); it.hasNext();) { // 利用迭代器取出集合中的元素
System.out.print(it.next());
}
System.out.println();
Iterator it = l.iterator(); //利用迭代器取出集合中的元素
while (it.hasNext()) {
System.out.print(it.next());
}
3、方法hasNext:没有指针下移操作,只是判断是否存在下一个元素
next:指针下移,返回该指针所指向的元素
remove:删除当前指针所指向的元素,一般和next方法一起用,这时候的作用就是删除next方法返回的元素
Object next():返回迭代器刚越过的元素的引用,返回值是Object,需要强制转换成自己需要的类型
boolean hasNext():判断容器内是否还有可供访问的元素
void remove():删除迭代器刚越过的元素