一、简介
1.1 模式定义
提供一种方法来访问聚合对象,而不是暴露这个对象内部表示,其别名为游标。迭代器模式是一种对象行为型模式。
1.2 使用场景
1)访问一个聚合对象的内容而无须暴露它的内部表示。将聚合对象的访问与内部数据的存储分离使得访问聚合对象时无须了解其内部实现细节。
2)需要为聚合对象提供多种遍历方式。
3)为遍历不同的集合结构提供一个统一的接口。当需要扩展聚合结构或者聚合结构增加的遍历方式时可以使用迭代器模式,它提供了聚合结构和迭代器的抽象定义。
1.3 优点
1)它支持一下不同的方式遍历一个聚合对象。对于复杂的聚合对象可以用多种方法来进行遍历,在迭代器模式中需要用一个不同的迭代器来替换原有迭代器即可改变遍历算法,也可以自己定义迭代器的子类以支持新的遍历方式。
2)迭代器简化了聚合类。因为引入了迭代器,在原有的聚合对象中不需要再自行提供遍历等数据操作方法,这样可以简化聚合类的设计。
3)在同一个聚合上可以有多个遍历。由于每个迭代器都保持自己的遍历状态,因此可以同时多一个聚合对象进行多个遍历操作。
4)在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码,满足“开闭原则”的要求。
1.4 缺点
由于迭代器模式将存储数据和遍历数据的职责分离增加新的聚合类须要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。
二、示例
2.1 结构图
2.2 迭代器类Iterator
public interface Iterator {
public boolean hasNext();
public Object next();
}
2.3 容器类Container
public interface Container {
public Iterator getIterator();
}
2.4 名字类
public class NameRepository implements Container{
public String[] names = {"Robert", "John", "Julie", "Lora"};
@Override
public Iterator getIterator() {
return new NameIterator();
}
private class NameIterator implements Iterator {
int index = 0;
@Override
public boolean hasNext() {
if (index < names.length) {
return true;
}
return false;
}
@Override
public Object next() {
if (hasNext()) {
return names[index++];
}
return null;
}
}
}