迭代器模式是一种使用频率很是高的设计模式,经过引入迭代器能够将数据的遍历功能从聚合对象中分离出来,聚合对象只负责存储数据,而遍历数据由迭代器来完成。因为不少编程语言的类库都已经实现了迭代器模式,所以在实际开发中,咱们只须要直接使用Java、C#等语言已定义好的迭代器便可,迭代器已经成为咱们操做聚合对象的基本工具之一。算法
1. 主要优势编程
迭代器模式的主要优势以下:设计模式
(1) 它支持以不一样的方式遍历一个聚合对象,在同一个聚合对象上能够定义多种遍历方式。在迭代器模式中只须要用一个不一样的迭代器来替换原有迭代器便可改变遍历算法,咱们也能够本身定义迭代器的子类以支持新的遍历方式。编程语言
(2) 迭代器简化了聚合类。因为引入了迭代器,在原有的聚合对象中不须要再自行提供数据遍历等方法,这样能够简化聚合类的设计。工具
(3) 在迭代器模式中,因为引入了抽象层,增长新的聚合类和迭代器类都很方便,无须修改原有代码,知足“开闭原则”的要求。设计
2. 主要缺点对象
迭代器模式的主要缺点以下:blog
(1) 因为迭代器模式将存储数据和遍历数据的职责分离,增长新的聚合类须要对应增长新的迭代器类,类的个数成对增长,这在必定程度上增长了系统的复杂性。接口
(2) 抽象迭代器的设计难度较大,须要充分考虑到系统未来的扩展,例如JDK内置迭代器Iterator就没法实现逆向遍历,若是须要实现逆向遍历,只能经过其子类ListIterator等来实现,而ListIterator迭代器没法用于操做Set类型的聚合对象。在自定义迭代器时,建立一个考虑全面的抽象迭代器并非件很容易的事情。开发
3. 适用场景
在如下状况下能够考虑使用迭代器模式:
(1) 访问一个聚合对象的内容而无须暴露它的内部表示。将聚合对象的访问与内部数据的存储分离,使得访问聚合对象时无须了解其内部实现细节。
(2) 须要为一个聚合对象提供多种遍历方式。
(3) 为遍历不一样的聚合结构提供一个统一的接口,在该接口的实现类中为不一样的聚合结构提供不一样的遍历方式,而客户端能够一致性地操做该接口。