设计模式之iterator模式到STL中iterator迭代器

设计模式之iterator模式到STL中iterator迭代器

近日看《设计模式:可复用面向对象软件的基础》一书中23种模式中就有iterator迭代模式,且篇幅颇大。机缘巧合、我在分析STL代码结构的时候,同样发现iterator迭代器,且占据相当大的地位。

从设计模式的角度来看iterator模式

ü     意图

提供一种方法顺序访问一个聚合对象中各个元素,而又不需要暴露对象的内部表示。我想GOF 的意图这次说的很明白了,就是我想遍历一个聚合对象。但又隐藏内部实现。该怎么办呢?本模式主要就是把遍历算法独立出来,使它和聚合对象去耦合。

ü     为何使用?

在面向对象设计中,一个难点就是辨认对象的职责。理想的状态下,一个类应该只有一个单一的职责。职责分离可以最大限度的去耦合,但是职责单一说起来容易,做起来难。具体到本模式,我们明显可以看到,一个聚合对象它提供了两个职责一是组织管理数据对象,二是提供遍历算法。如果该遍历算法有变化,那么我们就隔离变化 把它单独提取出来抽象为一个迭代器,这就是本模式的本质。

ü     角色

     1) 迭代器角色(Iterator):迭代器角色定义访问和遍历元素的接口。

 2) 具体迭代器角色(Concrete Iterator):具体迭代器角色实现迭代器接口,并对聚合对象遍历时跟综当前位置。

 3) 聚合角色(Container):定义创建具体迭代器角色的接口。

 4) 具体聚合角色(Concrete Container):具体聚合实现创建相应迭代器的接口,返回一个具体迭代器的实例。

总之、为了实现对于不同的聚集对象,客户端代码不会变化,因此我们引入了多态迭代器。为了创建多态迭代器又用到了factory method模式,为了使代码不倚赖于具体的聚合对象,迭代器是由聚合对象创建的。 有些时候,遍历算法可能需要访问聚合对象的私有变量,这时遍历算法也可以放在聚合对象(好处是不破坏封装),在遍历过程中迭代器对象保存当前的迭代状态,这一种迭代器我们称为游标。本模式可能实现起来比较麻烦,需要考虑迭代器的健壮性。因为有些时候我们遍历聚合对象时还会对该对象进行加入删除操作。在使用中发现 微软的 foreach 就不够健壮。

从STL角度来看iterator迭代器——无处不在的iterator迭代器

    可以毫不夸张的说,iterator设计模式的出现来至于STL,其模式的分析代码与STL中iterator迭代器代码从结构上来说基本相同。在STL中,iterator就是一条横快原理与实现统一的桥梁,缺少这根桥梁,STL容器操作就好象缺少了运算符。试分析STL代码就可发现,iterator无处不在。

从find()函数开始实现


#include<iostream>

#include<vector>

#include<deque>

#include<algorithm>

#include<list>

using namespace std;

void main()

{

    const int arraysize = 7;

    int ia[arraysize] = {0,1,2,3,4,5,6};

    vector<int> ivect(ia,ia+arraysize);

    list<int> ilist(ia,ia+arraysize);

    deque<int> idq;

 

    vector<int>::iterator it = find(ivect.begin(),ivect.end(),4);

    if(it == ivect.end())

        cout<< "4 not found!" <<endl;

    else

        cout<< "4 found!" <<endl;

 

    list<int>::iterator itl = find(ilist.begin(),ilist.end(),6);

    if(itl == ilist.end())

        cout<< "6 not found!" <<endl;

    else

        cout<< "6 found!" <<endl;

 

    deque<int>::iterator itd = find(idq.begin(),idq.end(),8);

    if(itd == idq.end())

        cout<< "8 not found!" <<endl;

    else

        cout<< "8 found!" <<endl;

}

结果如下


4 found!

6 found!

8 not found!

Press any key to continue

    总结、iterator精华之处在其本身,iterator作为原子,插入任何一个容器本身,傲游于STL之间。设计模式源至代码,却又可以驾驭代码,可谓是站在巨人的肩膀上成就经典的代码历史,良好的代码,抽象之后,便可以主导程序员的思维和提供创新的平台。

 

时间: 2024-12-04 07:51:07

设计模式之iterator模式到STL中iterator迭代器的相关文章

Java设计模式之Iterator模式介绍

所谓Iterator模式,即是Iterator为不同的容器提供一个统一的访问方式.本文以java中的容器为例,模拟Iterator的原理.需要的朋友可以参考下   1.首先定义一个容器Collection接口. 复制代码 代码如下: package com.njupt.zhb.learn.iterator; public interface Collection {  void add(Object o);  int size();  Iterator iterator(); } 2.定义一个I

Java源码分析:深入探讨Iterator模式

java.util包中包含了一系列重要的集合类.本文将从分析源码入手,深入研究一个集合类的内部结构,以及遍历集合的迭代模式的源码实现内幕. 下面我们先简单讨论一个根接口Collection,然后分析一个抽象类AbstractList和它的对应Iterator接口,并仔细研究迭代子模式的实现原理. 本文讨论的源代码版本是JDK 1.4.2,因为JDK 1.5在java.util中使用了很多泛型代码,为了简化问题,所以我们还是讨论1.4版本的代码. 集合类的根接口Collection Collect

设计模式的解析和实现(C++)之十八-Iterator模式

作用: 提供一种方法顺序访问一个聚合对象中各个元素,,而又不需暴露该对象的内部表示. UML结构图: 解析: Iterator几乎是大部分人在初学C++的时候就无意之中接触到的第一种设计模式,因为在STL之中,所有的容器类都有与之相关的迭代器.以前初学STL的时候,时常在看到讲述迭代器作用的时候是这么说的:提供一种方式,使得算法和容器可以独立的变化,而且在访问容器对象的时候不必暴露容器的内部细节,具体是怎么做到这一点的呢?在STL的实现中,所有的迭代器(Iterator)都必须遵照一套规范,这套

Java设计模式之迭代模式(Iterator模式)介绍_java

上了这么多年学,我发现一个问题,好象老师都很喜欢点名,甚至点名都成了某些老师的嗜好,一日不点名,就饭吃不香,觉睡不好似的,我就觉得很奇怪,你的课要是讲的好,同学又怎么会不来听课呢,殊不知:"误人子弟,乃是犯罪!"啊. 好了,那么我们现在来看老师这个点名过程是如何实现吧:1.老规矩,我们先定义老师(Teacher)接口类: 复制代码 代码如下: public interface Teacher {     public Iterator createIterator(); //点名 }

C++设计模式编程中的迭代器模式应用解析_C 语言

迭代器模式:提供一种方法顺序访问一个聚合对象中个各个元素,而不暴露该对像的内部表示. 迭代器模式应该是最为熟悉的模式了,最简单的证明就是我在实现组合模式.享元模式.观察者模式中就直接用到了 STL 提供的迭代器来遍历 Vector 或者 List数据结构. 迭代器模式也正是用来解决对一个聚合对象的遍历问题,将对聚合的遍历封装到一个类中进行,这样就避免了暴露这个聚合对象的内部表示的可能. 模式的动机: (1)一个聚合对象,如一个列表(List)或者一个集合(Set),应该提供一种方法来让别人可以访

JavaScript实现Iterator模式实例分析_javascript技巧

本文实例讲述了JavaScript实现Iterator模式的方法.分享给大家供大家参考.具体分析如下: 经常在网上看到有不少JS设计模式的示例.这里写一下JavaScript实现Iterator模式的方法,记录在此,仅作备忘: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quo

JavaScript实现Iterator模式实例分析

  本文实例讲述了JavaScript实现Iterator模式的方法.分享给大家供大家参考.具体分析如下: 经常在网上看到有不少JS设计模式的示例.这里写一下JavaScript实现Iterator模式的方法,记录在此,仅作备忘: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47

详解Java中Iterator迭代器的用法_java

迭代器(Iterator) 迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构.迭代器通常被称为"轻量级"对象,因为创建它的代价小. Java中的Iterator功能比较简单,并且只能单向移动: (1) 使用方法iterator()要求容器返回一个Iterator.第一次调用Iterator的next()方法时,它返回序列的第一个元素.注意:iterator()方法是java.lang.Iterable接口,被Collection继承

Java源码分析:深入探讨Iterator模式_JSP编程

java.util包中包含了一系列重要的集合类.本文将从分析源码入手,深入研究一个集合类的内部结构,以及遍历集合的迭代模式的源码实现内幕. 下面我们先简单讨论一个根接口Collection,然后分析一个抽象类AbstractList和它的对应Iterator接口,并仔细研究迭代子模式的实现原理. 本文讨论的源代码版本是JDK 1.4.2,因为JDK 1.5在java.util中使用了很多泛型代码,为了简化问题,所以我们还是讨论1.4版本的代码. 集合类的根接口Collection Collect