博客
关于我
设计模式之迭代器模式
阅读量:361 次
发布时间:2019-03-04

本文共 2716 字,大约阅读时间需要 9 分钟。

迭代器模式 Iterator Pattern

目录

迭代器模式(Iterator Pattern)是一种行为设计模式,旨在将对容器中包含的内部对象的访问委托给外部类,并通过Iterator(遍历器)按顺序进行访问。这种模式能够有效地处理按顺序遍历聚集对象集合的需求。

概念

迭代器模式的核心目标是提供一种高效且安全的方式来遍历容器中的元素。传统的实现方式可能面临以下问题:

  • 容器类承担了太多功能,既要实现容器的基本操作(如添加、删除)又要提供遍历功能,容易引起混乱。
  • 遍历逻辑与容器的其他操作耦合,难以维护和扩展。

迭代器模式通过引入专门的遍历器接口,解耦了遍历逻辑和容器的实现细节。它适用于以下场景:

  • 需要按顺序访问容器中的元素。
  • 需要对容器的元素进行统一的操作(如排序、过滤等)。

角色和职责

迭代器模式的主要角色包括:

  • Iterator(遍历器接口):定义了实现遍历功能的基本方法,如hasNext()next()等。
  • ConcreteIterator(具体遍历器类):实现了Iterator接口,根据具体的容器实现遍历逻辑。
  • Aggregate(容器接口):定义了容器的基本操作,如获取元素、判断大小等,并提供创建Iterator的方法。
  • ConcreteAggregate(具体容器类):实现了Aggregate接口,对容器中的元素进行管理,并提供Iterator的创建。

通过这种方式,遍历器可以通过持有容器的引用来访问容器中的元素,而无需直接暴露容器的内部结构。

案例分析

以下是一个使用迭代器模式的典型案例:

#include 
#include
using namespace std;typedef int Object;class MyIterator {public: virtual void First() = 0; virtual void Next() = 0; virtual bool IsDone() = 0; virtual Object CurrentItem() = 0;};class Aggregate {public: virtual Object getItem(int index) = 0; virtual MyIterator* CreateIterator() = 0; virtual int GetSize() = 0;};class ConcreteIterator : public MyIterator {public: ConcreteIterator(Aggregate* aggregate) { _aggregate = aggregate; _currentIndex = 0; } ~ConcreteIterator() { _aggregate = NULL; _currentIndex = 0; } virtual void First() { _currentIndex = 0; } virtual void Next() { if (_currentIndex < _aggregate->GetSize()) { _currentIndex++; } } virtual bool IsDone() { return _currentIndex == _aggregate->GetSize(); } virtual Object CurrentItem() { return _aggregate->getItem(_currentIndex); }protected:private: int _currentIndex; Aggregate* _aggregate;};class ConcreteAggregate : public Aggregate {public: ConcreteAggregate(int size) { for (int i = 0; i < size; i++) { _objects[i] = "Object" + (i + 1); } } ~ConcreteAggregate() { delete[] _objects; } virtual Object getItem(int index) { return _objects[index]; } virtual MyIterator* CreateIterator() { return new ConcreteIterator(this); } virtual int GetSize() { return _size; }protected:private: Object* _objects; int _size;};void main() { // 创建一个容器 ConcreteAggregate* aggregate = new ConcreteAggregate(5); // 创建一个遍历器 MyIterator* iterator = aggregate->CreateIterator(); // 遍历容器中的元素 while (!iterator->IsDone()) { Object currentItem = iterator->CurrentItem(); cout << currentItem << " "; iterator->Next(); } // 释放资源 delete iterator; delete aggregate;}

总结

迭代器模式通过引入遍历器接口,成功地将遍历逻辑与容器的实现细节解耦。这种模式不仅提高了代码的可维护性和扩展性,还为容器的其他操作提供了更干净的接口。通过合理使用迭代器模式,可以在保证安全性的前提下,简化对容器内部结构的访问,充分发挥容器与遍历器之间的依赖关系。

转载地址:http://gaur.baihongyu.com/

你可能感兴趣的文章
Oracle 表
查看>>
oracle 课堂笔记
查看>>
Oracle 返回结果集的 存储过程
查看>>
Oracle 递归
查看>>
Oracle 递归函数与拼接
查看>>
oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
查看>>
oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
查看>>
oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
查看>>
oracle--用户,权限,角色的管理
查看>>
Oracle-定时任务-JOB
查看>>
oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
查看>>
oracle00205报错,Oracle控制文件损坏报错场景
查看>>
Oracle10g EM乱码之快速解决
查看>>
Oracle10g下载地址--多平台下的32位和64位
查看>>
Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
查看>>
oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
查看>>
Oracle11G基本操作
查看>>
Oracle11g服务详细介绍及哪些服务是必须开启的?
查看>>
Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
查看>>
oracle12安装软件后安装数据库,然后需要自己配置监听
查看>>