设计模式之:装饰模式

原创 2016年08月29日 15:18:27

装饰模式UML图
装饰模式用于动态的往组件(Component)上添加功能。主要使用的场所为:

  • 需要扩展一个类的功能,或给一个类增加附加责任。
  • 需要动态的给一个对象增加功能,这些功能可以再动态地撤销。
  • 需要增加一些基本功能的排列组合而产生的非常大量的功能。

就上图而言,待扩展的类就是ConcreteComponent,附属的职责或者功能就是ConcreteDecorator身上带有的工能。装饰模式比较强大的地方在于:1)可以动态添加或者撤销职责或者功能。2)可以实现功能的排列组合而不用通过继承的方式。

这里写图片描述
举一个穿衣服的例子,UML图如上,代码如下:

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

class CAbstractAvator {
public:
    virtual void Decorate() = 0;
};

class CConcreteAvator : public CAbstractAvator{
    string m_name;
public:
    CConcreteAvator(const string& name) : m_name(name) {}
    void Decorate() override 
    {
        cout << "I'm " << m_name << ", I'm wearing: " << endl;
    }
};

class CAbstractDecorator : public CAbstractAvator{
protected:
    CAbstractAvator* pAvator = nullptr;
public:
    CAbstractDecorator(CAbstractAvator* p) : pAvator(p) {}
};

class CUnderWearDecorator : public CAbstractDecorator {
public:
    CUnderWearDecorator(CAbstractAvator* p) : CAbstractDecorator(p) {}
    void Decorate() override {
        pAvator->Decorate();
        cout << "Underwear" << endl;
    }
};

class CTshirtDecorator : public CAbstractDecorator {
public:
    CTshirtDecorator(CAbstractAvator* p) : CAbstractDecorator(p) {}
    void Decorate() override {
        pAvator->Decorate();
        cout << "Tshirt" << endl;
    }
};

class CSweatersDecorator : public CAbstractDecorator {
public:
    CSweatersDecorator(CAbstractAvator* p) : CAbstractDecorator(p) {}
    void Decorate() override {
        pAvator->Decorate();
        cout << "Sweaters" << endl;
    }
};

class CCoatDecorator : public CAbstractDecorator {
public:
    CCoatDecorator(CAbstractAvator* p) : CAbstractDecorator(p) {}
    void Decorate() override {
        pAvator->Decorate();
        cout << "Coat" << endl;
    }
};

void main()
{
    CAbstractAvator *pAvator = new CConcreteAvator("avator");
    pAvator = new CUnderWearDecorator(pAvator);
    pAvator = new CTshirtDecorator(pAvator);
    pAvator = new CSweatersDecorator(pAvator);
    pAvator = new CCoatDecorator(pAvator);
    pAvator->Decorate();
}

输出结果如下:

I'm avator, I'm wearing:
Underwear
Tshirt
Sweaters
Coat
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

设计模式之装饰模式

  • 2014-08-17 14:59
  • 68KB
  • 下载

设计模式之装饰模式

定义:动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更加灵活 举个例子来讲,假如我们要装扮我们自己,我们可以通过穿不同的衣服来装饰我们自己,例如我们可以:西装,领带,皮鞋...

设计模式_装饰模式

  • 2012-10-15 16:30
  • 23KB
  • 下载

设计模式(12)-装饰模式

思想:为一个对象已有的子类添加一些额外的职责。 场景:该模式的使用场景,主要是有的时候我们不愿意定义逻辑上新的子类,因为没有新的逻辑含义上的子类概念,而只是想为一个已存在的子类附加 一些职责。 实...

设计模式--装饰模式

  • 2012-07-13 21:52
  • 113KB
  • 下载

设计模式(九)装饰模式(Decorator)

一、咖啡店的故事这次我们借用HeadFirst中的咖啡店的故事来讨论一下装饰模式。咖啡店中有各种种类的咖啡和咖啡需要加的配料。有一家咖啡店为了提高效率打算开发一套咖啡订购系统,用户可以根据清单选择咖啡...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)