【设计模式】之二十三种设计模式--迭代器模式

迭代器模式

Provide a way to access the elements of an aggregate object sequentially without exposing its underlying representation.

(它提供一种方法访问一个容器对象中各个元素,而又不需暴露该对象的内部细节。)

通用类图

抽象迭代器类,定义访问和遍历元素的接口

具体迭代器类,继承抽象迭代器类,实现接口方法,与具体容器类关联

抽象容器类,提供创建具体迭代器的接口

具体容器类,继承抽象容器类,实现方法,创建初容纳迭代器的对象,使用具体迭代器类

通用源码

//抽象迭代器类
template <typename T>
class Iterator {
public:
    virtual T next() = 0;
    virtual booleam remove() = 0;
    virtual booleam hasxNext() = 0;
};
//具体迭代器类
template <typename T>
class ConcreteIterator: public Iterator {
public:
    ConcreteIterator(vector<T> v): vt(v) { }
    booleam hasxNext() {
        if(cursor == vt.size()) return false;
        else return true;
    }
    T next() {
        T t;
        if(hasxNext()) t = vt[cursor++];
        return t;
    }
    booleam remove() {
        vt.erase(vt.begin()+cursor++);
        return true;
    }

private:
    vector<T> vt;
    int cursor = 0;
};
//抽象容器类
template <typename T>
class Aggregate {
public:
    virtual void add(T) = 0;
    virtual void remove(T) = 0;
    virtual Iterator* iterator() = 0;
};
//具体容器类
template <typename T>
class ConcreteAggregate: public Aggregate {
public:
    void add(T t) {
        vt.insert(t);
    }
    void remove(T t) {
        auto iter = find(vt.begin(), vt.end(), t);
        vt.erase(iter);
    }
    Iterator* iterator() {
        return new ConcreteIterator(vt);
    }
private:
    vector<T> vt;
};

应用

迭代器模式已经被各种容器已经内部实现了,这里讲述的是迭代器的内部大概是怎么实现的,它的思想是如何。

在一般的开发中,不需要自己再次实现迭代器模式

示例代码

#include <iostream>
#include <string>

using namespace std;

class IProject {
public:
    virtual string getProjectInfo() = 0;
};

class Project : public IProject {
public:
    Project(string s, int n, int c): name(s), num(n), cost(c) { }
    string getProjectInfo() {
        string info;
        info = "name: " + name;
        info += "\tnumber: " + to_string(num);
        info += "\tcost: " + to_string(cost);
        return info;
    }
private:
    string name;
    int num;
    int cost;
};

int main() {
    IProject* p = new Project("2048", 2, 5000);
    cout << p->getProjectInfo() << endl;
    return 0;
}

打赏一个呗

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦