遍历聚合对象中的元素——迭代器模式(二)

转载 2013年12月05日 20:04:00

文章转载:http://blog.csdn.net/lovelion/article/details/9992243


2 迭代器模式概述

       在软件开发中,我们经常需要使用聚合对象来存储一系列数据。聚合对象拥有两个职责:一是存储数据;二是遍历数据。从依赖性来看,前者是聚合对象的基本职责;而后者既是可变化的,又是可分离的。因此,可以将遍历数据的行为从聚合对象中分离出来,封装在一个被称之为“迭代器”的对象中,由迭代器来提供遍历聚合对象内部数据的行为,这将简化聚合对象的设计,更符合“单一职责原则”的要求。

       迭代器模式定义如下:

迭代器模式(Iterator Pattern):提供一种方法来访问聚合对象,而不用暴露这个对象的内部表示,其别名为游标(Cursor)。迭代器模式是一种对象行为型模式。

       在迭代器模式结构中包含聚合和迭代器两个层次结构,考虑到系统的灵活性和可扩展性,在迭代器模式中应用了工厂方法模式,其模式结构如图3所示:

迭代器模式结构图

       在迭代器模式结构图中包含如下几个角色:

       ● Iterator(抽象迭代器):它定义了访问和遍历元素的接口,声明了用于遍历数据元素的方法,例如:用于获取第一个元素的first()方法,用于访问下一个元素的next()方法,用于判断是否还有下一个元素的hasNext()方法,用于获取当前元素的currentItem()方法等,在具体迭代器中将实现这些方法。

       ● ConcreteIterator(具体迭代器):它实现了抽象迭代器接口,完成对聚合对象的遍历,同时在具体迭代器中通过游标来记录在聚合对象中所处的当前位置,在具体实现时,游标通常是一个表示位置的非负整数。

       ● Aggregate(抽象聚合类):它用于存储和管理元素对象,声明一个createIterator()方法用于创建一个迭代器对象,充当抽象迭代器工厂角色。

       ● ConcreteAggregate(具体聚合类):它实现了在抽象聚合类中声明的createIterator()方法,该方法返回一个与该具体聚合类对应的具体迭代器ConcreteIterator实例。

       在迭代器模式中,提供了一个外部的迭代器来对聚合对象进行访问和遍历,迭代器定义了一个访问该聚合元素的接口,并且可以跟踪当前遍历的元素,了解哪些元素已经遍历过而哪些没有。迭代器的引入,将使得对一个复杂聚合对象的操作变得简单。

       下面我们结合代码来对迭代器模式的结构进行进一步分析。在迭代器模式中应用了工厂方法模式,抽象迭代器对应于抽象产品角色,具体迭代器对应于具体产品角色,抽象聚合类对应于抽象工厂角色,具体聚合类对应于具体工厂角色。

       在抽象迭代器中声明了用于遍历聚合对象中所存储元素的方法,典型代码如下所示:

[java] view plaincopy
  1. interface Iterator {  
  2.     public void first(); //将游标指向第一个元素  
  3.     public void next(); //将游标指向下一个元素  
  4.     public boolean hasNext(); //判断是否存在下一个元素  
  5.     public Object currentItem(); //获取游标指向的当前元素  
  6. }  

       在具体迭代器中将实现抽象迭代器声明的遍历数据的方法,如下代码所示:

[java] view plaincopy
  1. class ConcreteIterator implements Iterator {  
  2.     private ConcreteAggregate objects; //维持一个对具体聚合对象的引用,以便于访问存储在聚合对象中的数据  
  3.     private int cursor; //定义一个游标,用于记录当前访问位置  
  4.     public ConcreteIterator(ConcreteAggregate objects) {  
  5.         this.objects=objects;  
  6.     }  
  7.   
  8.     public void first() {  ......  }  
  9.           
  10.     public void next() {  ......  }  
  11.   
  12.     public boolean hasNext() {  ......  }  
  13.       
  14.     public Object currentItem() {  ......  }  
  15. }  

       需要注意的是抽象迭代器接口的设计非常重要,一方面需要充分满足各种遍历操作的要求,尽量为各种遍历方法都提供声明,另一方面又不能包含太多方法,接口中方法太多将给子类的实现带来麻烦。因此,可以考虑使用抽象类来设计抽象迭代器,在抽象类中为每一个方法提供一个空的默认实现如果需要在具体迭代器中为聚合对象增加全新的遍历操作,则必须修改抽象迭代器和具体迭代器的源代码,这将违反“开闭原则”,因此在设计时要考虑全面,避免之后修改接口

       聚合类用于存储数据并负责创建迭代器对象,最简单的抽象聚合类代码如下所示:

[java] view plaincopy
  1. interface Aggregate {  
  2.     Iterator createIterator();  
  3. }  

       具体聚合类作为抽象聚合类的子类,一方面负责存储数据,另一方面实现了在抽象聚合类中声明的工厂方法createIterator(),用于返回一个与该具体聚合类对应的具体迭代器对象,代码如下所示:

[java] view plaincopy
  1. class ConcreteAggregate implements Aggregate {    
  2.     ......    
  3.     public Iterator createIterator() {  
  4.     return new ConcreteIterator(this);  
  5.     }  
  6.     ......  
  7. }  

 

疑问

思考

理解迭代器模式中具体聚合类与具体迭代器类之间存在的依赖关系和关联关系。

【作者:刘伟   http://blog.csdn.net/lovelion


相关文章推荐

遍历聚合对象中的元素——迭代器模式(二)

遍历聚合对象中的元素——迭代器模式(二) 2 迭代器模式概述        在软件开发中,我们经常需要使用聚合对象来存储一系列数据。聚合对象拥有两个职责:一是存储数据;...

遍历聚合对象中的元素——迭代器模式(三)

3 完整解决方案       为了简化AbstractObjectList类的结构,并给不同的具体数据集合类提供不同的遍历方式,Sunny软件公司开发人员使用迭代器模式来重构AbstractObjec...

遍历聚合对象中的元素——迭代器模式

遍历聚合对象中的元素——迭代器模式(六) 6 迭代器模式总结        迭代器模式是一种使用频率非常高的设计模式,通过引入迭代器可以将数据的遍历功能从聚合对象中分离出来,聚合对象只...

遍历聚合对象中的元素——迭代器模式(一)

遍历聚合对象中的元素——迭代器模式(一)        20世纪80年代,那时我家有一台“古老的”电视机,牌子我忘了,只记得是台黑白电视机,没有遥控器,每次开关机或者换台都需...

遍历聚合对象中的元素——迭代器模式(五)

遍历聚合对象中的元素——迭代器模式(五) 5 JDK内置迭代器        为了让开发人员能够更加方便地操作聚合对象,在Java、C#等编程语言中都提供了内置迭代器。在Java集合框...

遍历聚合对象中的元素——迭代器模式(四)

4 使用内部类实现迭代器       在迭代器模式结构图中,我们可以看到具体迭代器类和具体聚合类之间存在双重关系,其中一个关系为关联关系,在具体迭代器中需要维持一个对具体聚合对象的引用,该关联关系的目...

遍历聚合对象中的元素——迭代器模式(Iterator Pattern)

一、引言 在上篇博文中分享了我对命令模式的理解,命令模式主要是把行为进行抽象成命令,使得请求者的行为和接受者的行为形成低耦合。在一章中,将介绍一下迭代器模式。下面废话不多说了,直接进入本博文的主题。...

STL中迭代器失效——用erase()方法遍历删除元素

STL迭代器失效的情况         STL中的容器按存储方式分为两类,一类是按以数组形式存储的顺序容器(如:vector 、deque);另一类是以不连续的节点形式存储的容器(如:list、se...

java迭代器模式实现正反向遍历

  • 2010年12月02日 22:06
  • 2KB
  • 下载

利用java迭代器Itetator遍历并删除HashMap中的元素问题

转自 http://www.blogjava.net/hwpok/archive/2011/11/05/362723.html 问题: 下面的代码试图利用HashMap的Iterator对象遍...
  • wdqbupt
  • wdqbupt
  • 2012年03月07日 03:47
  • 2668
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:遍历聚合对象中的元素——迭代器模式(二)
举报原因:
原因补充:

(最多只允许输入30个字)