迭代器是什么
Iterator接口提供了很多对集合元素进行迭代的方法。每一个集合类都包含了可以返回迭代器实例的迭代方法。迭代器可以在迭代的过程中删除底层集合的元素。
这个方法在调用时不需要任何参数,它是访问可迭代序列的一种方式,通常其从序列的第一个元素开始访问,直到所有的元素都被访问才结束。
Iterator接口里面的方法:
- boolean hasNext();
该方法英语判断集合对象是否还有下一个元素,如果已经是最后一个元素则返回false - E next();
把迭代器的指向移到下一个位置,同时,该方法返回下一个元素的引用 - default void remove() {
throw new UnsupportedOperationException(“remove”);
}
从迭代器指向的Collection中移除迭代器返回的最后一个元素,该操作使用的比较少 - default void forEachRemaining(Consumer<? super E> action) {
Objects.requireNonNull(action);
while (hasNext())
action.accept(next());
}
default void forEachRemaining(Consumer<? super E> action)对每个剩余元素执行给定的操作,直到所有元素都被处理或动作引发异常。 如果指定了该顺序,则按迭代的顺序执行操作。 动作抛出的异常被转发给呼叫者。
实现要求:
默认实现的行为如下:
while (hasNext()) action.accept(next());
参数 :
action - 要为每个元素执行的操作
异常 :
NullPointerException - 如果指定的动作为空
从以下版本开始:
1.8
迭代器的优点:
使用迭代器不要求事先准备好整个迭代过程中的所有元素。迭代器仅仅在迭代到某个元素时才计算该元素,而在这之前或之后元素可以不存在或者被销毁。因此迭代器适合遍历一些数量巨大甚至无限的序列。
迭代器的作用
迭代器—不必知道序列底层是怎么实现的,就可以利用迭代器来访问一个序列。
任何容器类,都必须有某种方式可以插入元素并将它们再次取回。毕竟,持有事物是容器的最基本的工作。对于List,add()是插入元素的方法之一,而get()是取出元素的方法之一。
迭代器(也是一种设计模式)的概念可以帮助我们达到一种目的。什么目的呢?能够将遍历序列的操作和序列底层相分离
迭代器是一个对象,它的工作是遍历并选择序列中的对象,而客户端程序员不需要知道该序列底层的结构。此外,迭代器通常被称为轻量级对象:创建它的代价小。因此,经常可以见到对迭代器有一些奇怪的限制;例如,java的Iterator只能单向移动,这个Iterator只能用来:
1. 使用方法iterator()要求容器返回一个Iterator。Iterator将准备好返回序列的第一个元素;
2. 使用next()获取序列中下一个元素;
3. 使用hasNext()检查序列中是否有元素;
4. 使用remove()将迭代器新返回的元素删除。
—能够将遍历序列的操作和序列底层相分离。也正因为如此,我们有时会说:迭代器统一了对容器的访问方式。
public class CrossContainerIteration {
public static void display(Iterator<Pet> it) {
while(it.hasNext()) {
Pet p = it.next();
System.out.print(p.id() + ":" + P + " ");
}
System.out.println();
}
}
上面这段代码显示了“迭代器”的威力,不知道Pet的类型,但是利用迭代器实现了对Pet序列的遍历。