答案是实现迭代器模式需分离遍历与聚合逻辑,定义抽象迭代器接口(如current、next、is_done),聚合类提供create_iterator创建具体迭代器,具体迭代器持聚合引用并维护索引,通过友元或接口访问数据,避免暴露结构,使用指针或引用减少拷贝,示例中MyVector用动态数组存储,VectorIterator实现正向遍历,用户通过统一接口访问元素,更换底层容器无需修改外部代码,支持扩展多种遍历方式,符合单一职责与开闭原则,需注意迭代器内存管理,推荐智能指针避免泄漏。
在C++中实现迭代器模式的关键是将遍历逻辑从聚合类中分离出来,这样既能隐藏内部数据结构,又能提供统一的访问接口。核心思路是定义一个抽象迭代器接口,让具体迭代器实现该接口,并通过聚合类提供创建迭代器的方法。
迭代器应支持基本操作:获取当前元素、移动到下一个位置、判断是否结束。可以使用纯虚函数定义通用行为。
假设聚合对象内部使用动态数组存储数据,但对外不可见。具体迭代器持有对聚合对象的引用或指针,并维护当前位置索引。
以下是一个简化实现:
class Iterator {
public:
virtual ~Iterator() = default;
virtual int current() const = 0;
virtual void next() = 0;
virtual bool is_done() const = 0;
};
class MyVector {
int* data;
size_t size;
public:
MyVector(int arr[], size_t n) : size(n) {
data = new int[n];
for (size_t i = 0; i < n; ++i) data[i] = arr[i];
}
~MyVector() { delete[] data; }
Iterator* create_iterator() const;
};
class VectorIterator : public Iterator {
const MyVector& vec;
size_t index;
public:
VectorIterator(const MyVector& v) : vec(v), index(0) {}
int current() const override { return vec.data[index]; }
void next() override { ++index; }
bool is_done() const override { return index >= vec.size; }
};
Iterator MyVector::create_iterator() const {
return new VectorIterator(this);
}
用户只需通过迭代器接口遍历元素,无需了解聚合内部如何存储。
基本上就这些。只要把访问和遍历分开,就能在不暴露细节的前提下灵活控制遍历过程。不复杂但容易忽略的是内存管理——记得释放迭代器,或者用智能指针自动处理。