介绍
迭代器模式是一种行为型设计模式,它提供一种顺序访问聚合对象中的各个元素,而不暴露聚合对象的内部表示。迭代器模式将遍历元素的责任委托给一个独立的迭代器对象,使得聚合对象和迭代算法可以独立变化而互不影响。
组成
结构图
场景
我们可以直接来看看ArrayList中的迭代器是怎么实现的,下面是ArrayList部分源码
代码
客户端代码
List<String> myList = new ArrayList<>();
myList.add("Item 1");
myList.add("Item 2");
myList.add("Item 3");
// 使用迭代器遍历ArrayList
Iterator<String> iterator = myList.iterator();
while (iterator.hasNext()) {
String item = iterator.next();
System.out.println(item);
}
部分源码
import java.util.*;
public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable {
// ...
/**
* Returns an iterator over elements of type {@code E}.
*
* @return an Iterator.
*/
public Iterator<E> iterator() {
return new Itr();
}
// ...
private class Itr implements Iterator<E> {
int cursor; // 游标,表示下一个要返回的元素的索引
int lastRet = -1; // 最后一个返回的元素的索引,初始值为-1
int expectedModCount = modCount; // 迭代器创建时的modCount
public boolean hasNext() {
return cursor != size;
}
@SuppressWarnings("unchecked")
public E next() {
checkForComodification(); // 检查迭代器创建后集合是否被修改过
int i = cursor;
if (i >= size) {
throw new NoSuchElementException();
}
Object[] elementData = ArrayList.this.elementData;
if (i >= elementData.length) {
throw new ConcurrentModificationException();
}
cursor = i + 1;
return (E) elementData[lastRet = i];
}
// 检查迭代器创建后集合是否被修改过
final void checkForComodification() {
if (modCount != expectedModCount) {
throw new ConcurrentModificationException();
}
}
}
// ...
}
ArrayList 其实就是具体聚集类,然后内部类Itr就是具体迭代器类,下面是一些关键点:
这里的 Itr 内部类是 ArrayList 的私有类,通过迭代器访问元素时,使用了 cursor 来迭代元素,同时进行了并发修改的检查。这样可以确保在迭代过程中,如果集合被修改,会抛出 ConcurrentModificationException,从而保证迭代器的安全性。