【第22期】观点:IT 行业加班,到底有没有价值?

设计模式之:装饰模式

原创 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
版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

设计模式C++实现(11)——装饰模式

分类: 软件设计模式c++实现 2011-08-11 08:42 18人阅读 评论(0) 收藏 举报  软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式...

装饰设计模式

装饰设计模式就是对已有的对象的功能进行增强简单小例子: class Person { void chifan() { System.out.println("chifan"); } } /* 为了不随便改变原有的代码。 还要增强chifan功能。 那么就定义一个类,对原有对象进行装饰。 */ class NewPerson { private Person p; NewPerson(Person p) { this.p = p; } public void newCh

设计模式C++实现(11)——装饰模式

软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式中运用了面向对象编程语言的重要特性:封装、继承、多态,真正领悟设计模式的精髓是可能一个漫长的过程,需要大量实践经验的积累。最...

java之装饰设计模式和继承的简单区别

http://jiangnanlove.iteye.com/blog/914120

设计模式- 装饰模式

设计模式- 装饰模式:装饰者模式,动态地将责任附加到对象上。若要扩展功能,装饰者提供了比继承更加有弹性的替代方案
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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