迭代器模式(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 具体容器具体容器实现容器接口定义