博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
迭代器模式
阅读量:4181 次
发布时间:2019-05-26

本文共 2824 字,大约阅读时间需要 9 分钟。

迭代器模式(Iterator pattern):提供一种方法访问一个容器对象中的各个元素,而又不需要暴露该对象的内部细节。

类图及定义

在这里插入图片描述

迭代器角色(Iterator):负责定义访问和遍历元素的接口。
具体迭代器角色(concrete iterator):实现接口,记录遍历中的当前位置。
容器角色(aggregate/container):负责提供创建具体迭代器角色的接口。
具体容器角色(concrete aggregate/container):实现创建具体迭代器角色的接口,这个具体迭代器角色和该容器的结构有关。

从结构上讲

  1. 迭代器模式在客户和容器之间添加了迭代器角色,很好地避免了容器细节的暴露。
  2. 具体迭代角色和具体容器角色是耦合在一起的,遍历算法是与容器的内部细节紧密相关的。
  3. 迭代器角色抽象了具体迭代角色,使客户程序更具一般性和重用性,被称为多态迭代(遍历不同的容器结构提供统一的接口)。
迭代器原理

Iterator依赖子类去实现,子类中的方法依赖容器中的内容去实现 Iterator接口,该对象必须依赖于具体容器,因为每个容器的数据结构不同,所 对于容器而言,具体的实现不重要,只要通过容器获取到该实现的迭代器对象即 Iterator接口是所有Iterator容器进行元素抽取出的公共接口。

迭代器的使用(java集合)

客户端先得到具体容器角色,然后通过具体容器角色得到具体迭代器角色。这样便可以使用具体迭代角色来遍历容器了。

Collection coll = new Arraylist();Iterator it = coll.iterator();while(it.hasNext()) {
it.next(); }

Demo

//聚集接口public interface Aggregate
{
public Iterator
createIterator();}//具体聚集类public class ConcreteAggregate
implements Aggregate
{
private List
items = new ArrayList
(); @Override public Iterator
createIterator() { return new ConcreteIterator
(this); } public int count() { return items.size(); } public T getItems(int index) { return items.get(index); } public void setItems(T item) { items.add(item); }}//迭代器接口public interface Iterator
{ public T first(); public T next(); public boolean isDone(); public T currentItem();}/** * 具体迭代器类,给出一种具体迭代的实现方式。 * 思考:迭代器表示的是一种迭代的行为,而聚集则是真正要被迭代的数据集合。 * 之所以要将迭代器和聚集分开,就是为了将行为与数据分开。 可类比Java中Iterator与Iterable的关系进行理解 */public class ConcreteIterator
implements Iterator
{ private ConcreteAggregate
concreteAggregate; private int current = 0; public ConcreteIterator(ConcreteAggregate
concreteAggregate) { this.setConcreteAggregate(concreteAggregate); } @Override public T first() { return concreteAggregate.getItems(0); } @Override public T next() { current++; if (current < concreteAggregate.count()) { return concreteAggregate.getItems(current); } return null; } @Override public boolean isDone() { return current >= concreteAggregate.count() ? true : false; } @Override public T currentItem() { return concreteAggregate.getItems(current); } public ConcreteAggregate
getConcreteAggregate() { return concreteAggregate; } public void setConcreteAggregate(ConcreteAggregate
concreteAggregate) { this.concreteAggregate = concreteAggregate; } public int getCurrent() { return current; } public void setCurrent(int current) { this.current = current; }}//客户端public class Client { public static void main(String[] args) { ConcreteAggregate
bus = new ConcreteAggregate
(); bus.setItems("大鸟"); bus.setItems("小菜"); bus.setItems("行李"); bus.setItems("老外"); bus.setItems("公交内部员工"); bus.setItems("小偷"); Iterator
iterator = new ConcreteIterator
(bus); while (!iterator.isDone()) { System.out.println(iterator.currentItem() + "请买票!"); iterator.next(); } }}

上一篇:

下一篇:

转载地址:http://dmrai.baihongyu.com/

你可能感兴趣的文章
给程序员入门的10点建议!
查看>>
送 35 本 Python 入门书籍
查看>>
如何快速上手Linux操作系统?
查看>>
微信QQ等主流应用上线国产系统UOS:界面曝光
查看>>
3天,让你的C++从入门到精通
查看>>
这个「微信年度报告」你被骗了吗?
查看>>
可怕啊,阿里面试!
查看>>
疯传!某大厂P8面试题库遭到泄露!
查看>>
中国编程第一人,一人抵一城!
查看>>
【微信红包封面】最新!最全!
查看>>
最近线上发生的两个坑爹锅!
查看>>
腾讯QQ的回应来了~
查看>>
最新5款微信红包封面,来了 !!!
查看>>
哦嚯,被微服务给坑了...
查看>>
SCI审稿人亲授:机器学习在智能化时代下的应用
查看>>
安卓微信 8.0 内测版来啦!
查看>>
我劝你不要再留QQ邮箱了
查看>>
真香!用 4K 高清显示器写代码!(包邮送一台)
查看>>
神器!各行业必备!低调使用
查看>>
B 站,牛逼!
查看>>