介绍
迭代器模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。、
迭代器模式属于行为型模式。
主要解决:不同的方式来遍历整个集合对象
如何解决:把在元素之间游走的责任交给迭代器,而不是聚合对象。
关键代码:定义接口:hasNext,next
应用实例:Java中的iterator
优点:
- 它支持以不同的方式遍历一个聚合对象
- 迭代器简化了聚合类
- 在同一个聚合上可以有多个遍历
- 在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码。
使用场景:
- 访问一个聚合对象的内容而无须暴露它的内部表示
- 需要为聚合对象提供多种遍历方式。
- 为遍历不同的聚合结构提供一个统一的接口。
注意事项:
迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据。
实现
创建一个叙述遍历方法的 Iterator 接口和一个返回迭代器的 Container 接口。实现了 Container 接口的实体类将负责实现 Iterator 接口。
IteratorPatternDemo,我们的演示类使用实体类 NamesRepository 来打印 NamesRepository 中存储为集合的 Names。
UML类图
创建iterator接口
1 | public interface Iterator { |
iterator接口定义了两个方法
- hasNext()查询集合的下一个索引处是否还有元素
- next()返回集合的下一个索引处的元素
创建集合接口
1 | public interface Container { |
为了演示方便,只定义了一个方法,用于获取迭代器iterator。
创建集合类
1 | public class NameRepository implements Container { |
重点在于定义了一个内部类实现了Iterator接口,通过判断索引是否超出限度实现hashNext()方法,返回数组[next]元素作为next()方法的实现.
测试集合类
1 | public class IteratorPatternDemo { |
小结
可以发现,定义了集合类之后,我们只需要根据集合类的特征,实现一个iterator接口的类,就可以用这个实现类来遍历集合类.
因此,迭代器模式的重点就是
- 创建集合类
- 根据集合类特征实现iterator接口
参考
- 本文作者: xczll
- 本文链接: https://xczllgit.github.io/2020/03/22/designPattern/2020-03-22-iteratorPattern/
- 版权声明: 本博客所有文章除特别声明外,均采用 MIT 许可协议。转载请注明出处!