迭代器模式(Iterator Pattern)
定义:Provide a way to access the elements of an aggregate object
sequentially without exposing its underlying
representation.(它提供一种方法访问一个容器对 象中各个元素,而又不需暴露该对象的内部细节。)
组成:
- Iterator 抽象迭代器抽象迭代器负责定义访问和遍历元素的接口,而且基本上是有固定的 3 个方法:
- first()获得第一个元素
- next()访问下一个元素
- isDone()是否已经访问到底部(Java 叫做 hasNext()方法)。
- ConcreteIterator 具体迭代器具体迭代器角色要实现迭代器接口,完成容器元素的遍历。
- Aggregate 抽象容器 容器角色负责提供创建具体迭代器角色的接口,必然提供一个类似 createIterator()这样的方法,在 Java 中一般是 iterator()方法。
- Concrete Aggregate 具体容器具体容器实现容器接口定义的方法,创建出容纳迭代器的对象。
ps:迭代器模式已经被淘汰,java 中已经把迭代器运用到各个聚集类
(collection)中了,使用 java 自带的
迭代器模式提供了一种遍历聚合对象的方式,不暴露其内部结构。包括抽象迭代器、具体迭代器和抽象容器等角色。Java中已内置迭代器在集合类中,适用于简化容器接口和支持多遍历。在实现迭代器时需注意容器元素增删的安全性和深层遍历问题。设计模式系列文章涵盖了创建型、结构型和行为型模式。
订阅专栏 解锁全文
206

被折叠的 条评论
为什么被折叠?



