设计模式16 - 迭代器模式

作者:billy
版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处

迭代器模式

迭代器模式(Iterator Pattern)用于顺序访问集合对象的元素,而又不暴露该对象的内部表示。迭代器模式属于行为型模式。

使用场景

  • 当需要为聚合对象提供多种遍历方式时。
  • 当需要为遍历不同的聚合结构提供一个统一的接口时。
  • 当访问一个聚合对象的内容而无须暴露其内部细节的表示时。

优缺点

  • 优点:
    1、它支持以不同的方式遍历一个聚合对象。
    2、迭代器简化了聚合类。
    3、在同一个聚合上可以有多个遍历。
    4、在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码。

  • 缺点:
    由于迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。

注意事项

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

UML结构图

在这里插入图片描述

代码实现

interface.h
创建抽象类 - 迭代器、容器;创建具体类 - 名称迭代器、名称容器

#include <string>
#include <vector>
#include <iostream>
using namespace std;

class Iterator  //基类-迭代器
{
public:
    Iterator() {}
    virtual ~Iterator() {}

    virtual bool hasNext() = 0;
    virtual string next() = 0;
};

class NameIterator: public Iterator //子类-名称迭代器
{
public:
    NameIterator(size_t index, std::vector<string> vector) : index(index), vector(vector) {}

    bool hasNext()
    {
        if(index < vector.size() - 1) {
            return true;
        }
        return false;
    }

    string next()
    {
        if(this->hasNext()) {
            return vector.at(index++);
        }
        return nullptr;
    }

private:
    size_t index;
    std::vector<string> vector;
};

class Container //基类-容器
{
public:
    Container() {}
    virtual ~Container() {}

    virtual Iterator* getIterator() = 0;
};

class NameRepository: public Container  //子类-名称容器
{
public:
    NameRepository(size_t index, std::vector<string> vector) : index(index), vector(vector) {}

    Iterator* getIterator()
    {
        return new NameIterator(index, vector);
    }

private:
    size_t index;
    std::vector<string> vector;
};

main.cpp
实例应用 - 通过名称迭代器遍历名称容器并输出所有内容

#include "interface.h"

int main()
{
    std::vector<string> vector;
    vector.push_back("Billy");
    vector.push_back("Alice");
    vector.push_back("Kitty");
    vector.push_back("Ben");
    vector.push_back("Jason");
    vector.push_back("Jack");
    vector.push_back("Miss");

    NameRepository *nameRepository = new NameRepository(0, vector);

    for(Iterator *iterator = nameRepository->getIterator(); iterator->hasNext();)
    {
        cout << iterator->next() << endl;
    }
}

运行结果:
Billy
Alice
Kitty
Ben
Jason
Jack
发布了61 篇原创文章 · 获赞 218 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_34139994/article/details/95641119