迭代器模式定义:提供一种方法顺序訪问一个聚合对象中各个元素,而又不须要暴露该对象。

迭代器分内部迭代器和外部迭代器。内部迭代器与对象耦合紧密,不推荐使用。

外部迭代器与聚合容器的内部对象松耦合,推荐使用。

迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既能够做到不暴露集合的内部结构,又可让外部代码透明地訪问集 合内部的数据。

并且,能够同一时候

定义多个迭代器来遍历。互不冲突。

对于迭代器,參考STL迭代器,仅仅须要使用详细容器的迭代器就能够遍历该容器内的聚合对象。也能够借助迭代器实现对象的诸如加入、删除和调用。

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

2.详细迭代器角色(Concrete Iterator):详细迭代器角色要实现迭代器接口,并要记录遍历中的当前位置。

3.集合角色(Aggregate):集合角色负责提供创建详细迭代器角色的接口。

4.详细集合角色(Concrete Aggregate):详细集合角色实现创建详细迭代器角色的接口——这个详细迭代器角色于该集合的结构相关。

C++迭代器模式(与STL接口保持一致)代码:

#include <iostream>
#include <vector>
using namespace std; template<class Item>
class Iterator
{
public:
virtual void first()=0;
virtual void next()=0;
virtual Item* currentItem()=0;
virtual bool isDone()=0;
virtual ~Iterator(){}
}; template<class Item>
class ConcreteAggregate; template<class Item>
class ConcreteIterator : public Iterator <Item>
{
ConcreteAggregate<Item> * aggr;
int cur;
public:
ConcreteIterator(ConcreteAggregate<Item>*a):aggr(a),cur(0){}
virtual void first()
{
cur=0;
}
virtual void next()
{
if(cur<aggr->getLen())
cur++;
}
virtual Item* currentItem()
{
if(cur<aggr->getLen())
return &(*aggr)[cur];
else
return NULL;
}
virtual bool isDone()
{
return (cur>=aggr->getLen());
}
}; template<class Item>
class Aggregate
{
public:
virtual Iterator<Item>* createIterator()=0;
virtual ~Aggregate(){}
}; template<class Item>
class ConcreteAggregate:public Aggregate<Item>
{
vector<Item >data;
public:
ConcreteAggregate()
{
data.push_back(1);
data.push_back(2);
data.push_back(3);
}
virtual Iterator<Item>* createIterator()
{
return new ConcreteIterator<Item>(this);
}
Item& operator[](int index)
{
return data[index];
}
int getLen()
{
return data.size();
}
}; int main()
{
Aggregate<int> * aggr =new ConcreteAggregate<int>();
Iterator<int> *it=aggr->createIterator(); for(it->first();!it->isDone();it->next())
{
cout<<*(it->currentItem())<<endl;
}
delete it;
delete aggr;
return 0;
}

最新文章

  1. ASP.NET 系列:单元测试之SmtpClient
  2. Swift开发小技巧--识别选中照片中的二维码
  3. 六间房PK同时观看两方视频(绕过VIP限制)+直播状态批量监测
  4. javascript delete方法
  5. POJ2115 C Looooops 模线性方程(扩展欧几里得)
  6. android客户端从服务器端获取json数据并解析的实现代码
  7. 关于bootstrap--排版(标题、强调、背景、插入符等)
  8. iOS设备定位
  9. 经典HTML5小游戏 支持各种浏览器 (围住神经猫)
  10. cv2的安装
  11. Executor, ExecutorService 和 Executors 间的不同
  12. SVN被锁定的几种解决方法
  13. python的datetime常用方法
  14. Redis持久化——RDB快照
  15. 使用java中replaceAll方法替换字符串中的反斜杠
  16. absolute float 比较分析
  17. ansible入门七(实战)
  18. hadoop-2.2.0 HA配置
  19. css总结20:TCP通信协议WebSocket
  20. Java线程同步打印ABC

热门文章

  1. 学习笔记:javascript中的Generator函数
  2. .net web api跨域问题
  3. 抽象工厂模式(AbsFactory)C++实现
  4. 在django中应用装饰器(一)
  5. rem简单实现移动端适配
  6. open source project for recommendation system
  7. AndroidStudio/Intellij 快捷键
  8. LoadRunner时间戳函数web_save_timestamp_param
  9. 关于table排版
  10. (转)RabbitMQ学习之安装