一、UML图
二、概念
迭代器模式(Iterator):提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示。
三、说明
什么时候用?
(1)当你需要访问一个聚集对象,而且不管这些对象时什么都需要遍历的时候,你就应该考虑用迭代器模式。
(2)你需要对聚集有多种遍历时,可以考虑用迭代器模式。
(3)为遍历不同的聚集结构提供如开始、下一个、是否结束、当前哪一项等统一的接口。
迭代器模式的好处?
迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据。
四、C++实现
(1)Iterator.h
#ifndef ITERATOR_H
#define ITERATOR_H
#include <vector>
#include <iostream>
#include "Aggregate.h"
typedef std::string object;
//迭代器抽象类
class Iterator
{
public:
virtual object First()=0;
virtual object Next()=0;
virtual bool IsDone()=0;
virtual object CurrentItem()=0;
};