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

简介: 设计模式之iterator模式到STL中iterator迭代器 近日看《设计模式:可复用面向对象软件的基础》一书中23种模式中就有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之间。设计模式源至代码,却又可以驾驭代码,可谓是站在巨人的肩膀上成就经典的代码历史,良好的代码,抽象之后,便可以主导程序员的思维和提供创新的平台。

 

目录
相关文章
|
22天前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
2月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。
|
25天前
|
设计模式 开发者 Python
Python编程中的设计模式:工厂方法模式###
本文深入浅出地探讨了Python编程中的一种重要设计模式——工厂方法模式。通过具体案例和代码示例,我们将了解工厂方法模式的定义、应用场景、实现步骤以及其优势与潜在缺点。无论你是Python新手还是有经验的开发者,都能从本文中获得关于如何在实际项目中有效应用工厂方法模式的启发。 ###
|
18天前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
37 1
|
1月前
|
设计模式 Java Kotlin
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
本教程详细讲解Kotlin语法,适合希望深入了解Kotlin的开发者。对于快速学习Kotlin语法,推荐查看“简洁”系列教程。本文重点介绍了构建者模式在Kotlin中的应用与改良,包括如何使用具名可选参数简化复杂对象的创建过程,以及如何在初始化代码块中对参数进行约束和校验。
22 3
|
2月前
|
设计模式 算法 安全
设计模式——模板模式
模板方法模式、钩子方法、Spring源码AbstractApplicationContext类用到的模板方法
设计模式——模板模式
|
2月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:如何提高代码的可维护性与扩展性在软件开发领域,PHP 是一种广泛使用的服务器端脚本语言。随着项目规模的扩大和复杂性的增加,保持代码的可维护性和可扩展性变得越来越重要。本文将探讨 PHP 中的设计模式,并通过实例展示如何应用这些模式来提高代码质量。
设计模式是经过验证的解决软件设计问题的方法。它们不是具体的代码,而是一种编码和设计经验的总结。在PHP开发中,合理地使用设计模式可以显著提高代码的可维护性、复用性和扩展性。本文将介绍几种常见的设计模式,包括单例模式、工厂模式和观察者模式,并通过具体的例子展示如何在PHP项目中应用这些模式。
|
2月前
|
设计模式 Java Spring
spring源码设计模式分析-代理设计模式(二)
spring源码设计模式分析-代理设计模式(二)
|
1月前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
38 0
|
2月前
|
设计模式 Java
Java设计模式-工厂方法模式(4)
Java设计模式-工厂方法模式(4)