`
huobengluantiao8
  • 浏览: 1029219 次
文章分类
社区版块
存档分类
最新评论

《GOF设计模式》学习笔记—Iterator迭代器

 
阅读更多
官方描述
提供一种方法顺序访问一个聚合对象中的各元素,而又无需暴露该聚合对象的内部表示。
我的理解
1、价值所在:
Iterator迭代器模式相对于其他模式显得对于要处理的问题更具体一些,它把一个聚合对象中元素访问和遍历操作从该聚合对象内部分离出去,从而提供了以下三方面的好处:
1)简化聚合类型接口
因为聚合对象不再需要直接对外提供访问和遍历自己内部元素的服务,所以简化了聚合对象类型的接口;
2)便于提供多种类型的迭代算法
我们可以很方便地通过提供多种迭代器,以对聚合对象进行不同形式的访问和遍历,而这种扩展对聚合对象本身不产生影响;
3)可以对聚合对象同时进行多个遍历
对于一个聚合对象,我们可以创建多个迭代器与其关联,这样我们就可以同时对该聚合对象进行多个遍历操作;
2、迭代器与聚合类的关系
由于迭代器是将本属于聚合对象的元素访问和遍历操作从聚合对象中分离,并进行独立的包装,所以迭代器和聚合对象本身是密切关联的。
迭代器在创建的时候,至少在被使用之前,必须知道它要访问的具体聚合对象,并且由于不同类型的聚合对象需要的迭代器也往往不同,所以让聚合对象创建相关联的迭代器就显得非常的自然和合情合理,通过Factory Method可以很好的实现这一点。
3、实际应用
在Java中,容器类Collection的实现即采用了Iterator模式,对于各种具体的Collection子类,如ArrayList、LinkedList、HashSet等,都具体实现了相应的Iterator子类,并通过Factory Method模式将集合类和对应的迭代器类相关联,这样既简化了集合类的设计,又便于用户使用和扩展。JDK中的集合类/迭代器类部分结构图如下:
4、备注
1)Iterator模式的结构图
2)Iterator模式参与者描述
1、Iterator(迭代器)
——迭代器定义访问和遍历元素的接口。
2、ConcreteIteratro(具体迭代器)
——具体迭代器实现迭代器的接口;
——对该聚合遍历时跟踪当前位置;
3、Aggregate(聚合)
——聚合定义创建相应迭代器对象的接口;
4、ConcreteAggregae(具体聚合类)
——具体聚合实现创建相应迭代器的接口,该操作返回ConcreteIterator的一个适当的实例
5、参考资料
GOF《设计模式——可复用面向对象软件的基础》
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics