1.场景
大多数程序员家里都有很多书籍,但是书多以后,收纳就成了个问题,想要找书的时候,可能在翻遍了整个房间才找到自己想要找的书;所以这种情况就需要一个书架。书架的作用就是放置书,同时在找书的时候也很方便。如果类比一下在书架上找书这个步骤是不是很像代码中的遍历。
2.迭代器模式结构图
3.实现迭代器模式
Aggregate接口的作用就是表示这是一个集合,或者说只要继承了Aggregate就是一个集合,你可以类比List,就像ArrayList实现于List接口一样。
Iterator接口的作用是迭代器的接口,定义了迭代器所具备的方法。
Bookshelf则是我们的书架,他就是一个集合,所以他实现了Aggregate。主要的方法就是iterator,类似于ArrayList中的迭代器,返回一个迭代对象。
BookshelfIterator是一个具体迭代器,是对Iterator的一个实现,整个迭代的代码都在BookshelfIterator中进行实现。
测试一下迭代器模式,可以看到具体的输出如下,能够实现遍历。迭代器模式的好处就在于我们调用.iterator返回迭代器后,并不需要关心怎么实现的而且我们实际上并不是通过书架类Bookshelf进行的遍历,这样如果有一天Bookshelf中存放书的List改为数组,实际上只需要满足迭代器的规范即可,而我们并不需要去更改下面遍历的代码,也不需要更改BookshelfIterator。同时迭代器模式也将具体的实现和遍历进行了分离。
4.JDK中的迭代器模式
关于迭代遍历你是否经常在集合类中看到呢?如果让你去实现这个集合类,可能会将遍历这个方法写在每个集合类的内部,但是这样每个集合类都存在这样一个遍历,且功能都是遍历。那么能不能抽取出来呢?
可以看到我们常用的集合中都使用了这种设计模式例如ArrayList,可以看到实际上使用迭代器遍历的时候,调用的是Itr类,同时Iter类中对定义了Iterator接口的方法实现实现了遍历,这样无论是什么样的集合,只要能够满足Itr类的要求都可以使用Itr进行遍历,同时如果对ArryList进行更改后只要满足迭代器的实现,那么实际上我们实际上编写的迭代遍历是不需要进行更改的。
参考文献:《图解设计模式》