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

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

 
阅读更多

设计模式之iterator模式到STLiterator迭代器

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

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

ü 意图

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

ü 为何使用?

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

ü 角色

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

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

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

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

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

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

可以毫不夸张的说,iterator设计模式的出现来至于STL,其模式的分析代码与STLiterator迭代器代码从结构上来说基本相同。在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之间。设计模式源至代码,却又可以驾驭代码,可谓是站在巨人的肩膀上成就经典的代码历史,良好的代码,抽象之后,便可以主导程序员的思维和提供创新的平台。

分享到:
评论

相关推荐

    面向对象方法(STL_analysis)of_Iterator迭代器

    面向对象方法(STL_analysis)of_Iterator迭代器,这个文档对这进行了详细介绍,供参考!

    仿std&&list;的iterator迭代器

    仿std&&list;的iterator迭代器,有助于加深对stl中各种封装类的理解

    C++ STL 迭代器 入门

    关于 C++ STL 迭代器 的最佳入门教程之一。 轻松、幽默、干脆、一看就会!却不乏C++编程思想之启发!

    C++设计模式之迭代器模式(Iterator)

    迭代器在STL运用广泛,类似容器的迭代已经成为其重要特性,而迭代器模式则是利用迭代器概念进行的抽象运用,迭代器模式运用广泛和有用,因为其能够不考虑数据的存储方式,而是直接面对数据进行迭代,也就是说我们...

    PHP设计模式之迭代器(Iterator)模式入门与应用详解

    本文实例讲述了PHP设计模式之迭代器(Iterator)模式。分享给大家供大家参考,具体如下: 迭代器有时又称光标(cursor)是程式设计的软件设计模式,可在容器物件(container,例如list或vector)上遍访的接口,设计...

    STL.rar_STL_STL PPT_iterator_stl p

    stl的入门ppt 很好用哦,分为导入 STL的概念与组成 Iterator(迭代器) Container(容器) Algorithm(算法) Adaptors(配接器)

    iterator.zip

    STL iterator相关代码

    PHP设计模式之PHP迭代器模式讲解

    有些面向对象语言像Java, C#, Python, Delphi都已将Iterator的特性内建语言当中,完美的跟语言整合,我们称之隐式迭代器(implicit iterator),但像是C++语言本身就没有Iterator的特色,但STL仍利用template实作了...

    标准模板库STL

    这样,在STL中迭代器就将算法和容器联系起来了,通过迭代器,算法函数可以访问容器中指定位置的元素,而无需关心元素的具体类型。 STL迭代器部分主要由头文件和&lt;iterator&gt;组成。 (4)函数对象(Function ...

    Qt5开发及实例-CH203.rar,Qt5使用STL风格迭代器的代码

    实例CH203,使用STL风格迭代器。 (a) list.insert(list.end(),j):使用QList&lt;T&gt;::insert()函数插入10个整数值。此函数有两个参数:第一个参数是QList&lt;T&gt;::iterator类型,表示在该列表项之前插入一个新的列表项(使用...

    Effective STL(中文)

    :operator[]和map-insert之间仔细选择 条款25:熟悉非标准散列容器 迭代器 条款26:尽量用iterator代替const_iterator,reverse_iterator和const_reverse_iterator 条款27:用distance和advance把const_...

    计算部分的数量树- 了解树的表示方法Map容器- 了解如何日用标准库中的map容器以及迭代器递归- 了解如何构造一个递归的解决方案去解决一个问题

    计算部分的数量 前提, 目标, 结果 前提: 学生需要掌握以下机能 • 树- 了解树的表示方法 • Map容器- 了解如何日用标准库中的map容器以及迭代器 • 递归- 了解如何构造一个递归的解决方案去解决一个问题

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

    迭代器模式应该是最为熟悉的模式了,最简单的证明就是我在实现组合模式、享元模式、观察者模式中就直接用到了 STL 提供的迭代器来遍历 Vector 或者 List数据结构。 迭代器模式也正是用来解决对一个聚合对象的遍历...

    effective stl stl 技巧

    迭代器 条款26:尽量用iterator代替const_iterator,reverse_iterator和const_reverse_iterator 条款27:用distance和advance把const_iterator转化成iterator 条款28:了解如何通过reverse_iterator的base得到...

    STL入门,STL基本知识,核心东西

    STL入门 导入 STL的概念与组成 Iterator(迭代器) Container(容器) Algorithm(算法) Adaptors(配接器)

    STL源码剖析.pdg

    3.4.5 迭代器相应型别之五iterator_category 092 以advanced() 为例 093 消除 "单纯传递调用函数" 097 以distance() 为例 098 3.5 std::iterator class 的保证 099 3.6 iterator相关源码完整重列 101 3.7 sgi ...

    自编MStirng(类似std::string)以及配套的4种iterators

    编写它的目的不是为了使用,而是为了熟悉stl算法及迭代器的原理。其中MString仅支持简单的基本操作,但在此基础上扩展其他功能已经很容易。主要精力放在了iterator的编写上,iterator开发了全部功能,使用了模板,...

    STL模板库思维导图

    STL的从广义上讲分为三类:algorithm(算法)、container(容器)和iterator(迭代器),容器和算法通过迭代器可以进行无缝地连接。几乎所有的代码都采 用了模板类和模板函数的方式,这相比于传统的由函数和类组成...

    STL入门 STL的概念与组成

    STL入门 STL的概念与组成 Iterator(迭代器) Container(容器) Algorithm(算法) Adaptors(配接器)

    C++迭代器介绍(iterator、const_iterator、reverse_interator、const_reverse_interator)

    C++的STL定义了5种迭代器 输入迭代器:提供了对其指向元素的只读操作以及前++和后++操作符 输出迭代器:提供了对其指向元素的写操作和++操作符 向前迭代器:具有++操作符 双向迭代器:既具有++操作符也具有–...

Global site tag (gtag.js) - Google Analytics