【C++】Chapter16:迭代器模式

来源:互联网 发布:大数据测试工程师招聘 编辑:程序博客网 时间:2024/05/16 10:22

迭代器模式(Iterator)

提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示。当你需要访问一个聚集对象,而且不管这些对象是什么都需要遍历的时候,就应该考虑用迭代器模式。同时需要对聚集有多种方式遍历时,可以考虑用迭代器模式。为遍历不同的聚集结构提供如开始、下一个、是否结束、当前哪一项等统一接口。迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据。

 

实际应用

工程结构:

(1)抽象迭代器 Iterator.h

(2)抽象聚集类 Aggregate.h

(3)具体迭代器 ConcreteIterator.h

(4)具体聚集类 ConcreteAggregate.cpp、ConcreteAggregate.h

(5)客户端 IteratorApp.cpp

(1)抽象迭代器 Iterator.h

 

(2)抽象聚集类 Aggregate.h

 

(3)具体迭代器 ConcreteIterator.h

 

(4)具体聚集类 ConcreteAggregate.cpp、ConcreteAggregate.h

 

(5)客户端 IteratorApp.cpp