经典的设计模式15——迭代器模式

文章目录

  • 迭代器模式


迭代器模式

迭代器模式:提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示。
就是说当需要访问一个聚集对象,而且不管这些对象是什么都需要遍历的时候,就应该考虑用迭代器模式。需要对聚集有多种方式遍历时,可以考虑用迭代器模式,比如从头到尾遍历,从尾到头遍历。
迭代器模式与组合模式可以一起使用,组合模式中通常可以使用迭代器模式来遍历组合对象的子对象集合,而无需关心具体存放子对象的聚合结构。
结构:
抽象聚合角色:定义存储添加删除聚合元素以及创建迭代器对象的接口。
具体聚合角色:实现抽象聚合类,返回一个具体的迭代器实例。
抽象迭代器角色:定义访问和遍历聚合元素的接口,通常包含hasnext(),next()方法。
具体迭代器角色:实现抽象迭代器接口中所定义的方法,完成聚合对象的遍历,记录遍历的当前位置。
优点:
它支持以不同的方式遍历一个集合对象,在同一个聚合对象上可以定义多种遍历方式。在迭代器模式中只需要用一个不同的迭代器来替换原有迭代器即可改变遍历算法,我们也可以自己定义迭代器的子类以支持新的遍历方式。
迭代器简化了聚合类。由于引入了迭代器,在原有的聚合对象中不需要再自行提供数据遍历等方法,这样可以简化聚合类的设计。
在迭代器模式中,由于引入了抽象层,增加新的聚合类和迭代器类都很方便,无须修改原有代码,满足开闭原则。
缺点:
增加了类的个数,在一定程度上增加了系统的复杂性。
使用场景:
当需要为聚合类提供多种遍历方式时。
当需要为遍历不同的聚合结构提供一个统一的接口时。
当访问一个聚合对象的内容而无须暴露其内部细节的表示时。

你可能感兴趣的:(设计模式,设计模式,迭代器模式,组合模式)