设计模式:迭代器模式(C++实现)

迭代器模式是一种行为型设计模式,用于提供一种遍历集合对象的统一接口。在C++中,可以使用以下步骤实现迭代器模式:

#include 
#include 

// 抽象迭代器接口
class Iterator
{
public:
    virtual bool hasNext() = 0;
    virtual int next() = 0;
};

// 集合类接口
class Aggregate
{
public:
    virtual Iterator *createIterator() = 0;
    virtual void addItem(int item) = 0;
    virtual int getItem(int index) = 0; // 添加getItem()方法
    virtual int getSize() = 0;          // 添加getSize()方法
};

// 具体迭代器类
class ConcreteIterator : public Iterator
{
private:
    Aggregate *aggregate;
    int position;

public:
    ConcreteIterator(Aggregate *a) : aggregate(a), position(0) {}

    bool hasNext() override
    {
        return position < aggregate->getSize();
    }

    int next() override
    {
        int item = aggregate->getItem(position);
        position++;
        return item;
    }
};

// 具体集合类
class ConcreteAggregate : public Aggregate
{
private:
    std::vector<int> items;

public:
    Iterator *createIterator() override
    {
        return new ConcreteIterator(this);
    }

    void addItem(int item) override
    {
        items.push_back(item);
    }

    int getItem(int index) override
    { 
        // 实现getItem()方法
        return items[index];
    }

    int getSize() override
    { 
        // 实现getSize()方法
        return items.size();
    }
};

int main()
{
    ConcreteAggregate aggregate;
    aggregate.addItem(1);
    aggregate.addItem(3);
    aggregate.addItem(2);

    Iterator *iterator = aggregate.createIterator();
    while (iterator->hasNext())
    {
        int item = iterator->next();
        // 处理每个元素
        std::cout << item << "\n";
    }

    delete iterator;

    return 0;
}

运行结果:

1
3
2

你可能感兴趣的:(设计模式,设计模式,迭代器模式,c++)