C++设计模式-装饰器模式

一、概念

从外部给类添加新职能,而不用去修改原始的类(满足面向对象的开放-封闭原则),扩展性好,可复用程度高。

二、原理

  • Component 为一个抽象对象,装饰器和具体需要被装饰的对象都继承自该抽象对象,最重要的一点是Decrator维护了一个需要被装饰的对象的引用,从而达到为该对象添加职能的目的。
  • demo:为一个蛋糕添加装饰 。蛋糕店刚生产出来的蛋糕是最原始的,只是一个蛋糕原型,我们需要再这个蛋糕上加上奶油,加上巧克力,加上瓜子仁,写上字等,将原始蛋糕作为一个Cake类,我们给这个Cake类的对象作装饰,为了不破坏开放-封闭原则,也为了更好的拓展,我们不能直接在Cake这个类里修改,而应该通过装饰器来给这个蛋糕做装饰。

三、代码实现

1.component.h

component.h 这个文件描述原始对象和需要被装饰的对象

cpp 复制代码
#ifndef DECRATOR_COMPONENT_H
#define DECRATOR_COMPONENT_H
using namespace std;

//定义一个原始的抽象类蛋糕,装饰器的功能是给蛋糕加上各种装饰,如奶油,巧克力,瓜子仁,花生米等
class Cake{
public:
    Cake(){};
    ~Cake(){};

    virtual void showCake() = 0;//纯虚函数
    string m_sName;
};

class ConcreteCake:public Cake{
public:
    ConcreteCake(){
        m_sName = "原始蛋糕";
    }
    ~ConcreteCake(){}

    virtual void showCake()
    {
        cout << m_sName << endl;
    }
};
#endif //DECRATOR_COMPONENT_H

2.decorator.h

decorator.h文件描述具体的装饰器的类

cpp 复制代码
#ifndef DECRATOR_DECORATOR_H
#define DECRATOR_DECORATOR_H
#include "component.h"
class CakeDecorator:public Cake{
public:
    CakeDecorator(){}
    ~CakeDecorator(){}

    virtual void showCake() = 0;

protected:
    Cake *m_pCake;//需要被装饰的对象,为Cake对象添加装饰
};

class CakeDecoratorMilk:public CakeDecorator{
public:
    CakeDecoratorMilk(Cake *pCake)
    {
        m_pCake = pCake;
    }
    ~CakeDecoratorMilk(){
    }

    virtual void showCake() {
        m_sName = m_pCake->m_sName + "加奶油";
        cout << m_sName << endl;
    }
};

class CakeDecoratorCholate:public CakeDecorator{
public:
    CakeDecoratorCholate(Cake *pCake){
        m_pCake = pCake;
    }
    ~CakeDecoratorCholate(){}

    virtual void showCake(){
        m_sName = m_pCake->m_sName + "加巧克力";
        cout << m_sName << endl;
    }
};

#endif //DECRATOR_DECORATOR_H

3.main.cpp

cpp 复制代码
#include <iostream>
#include "component.h"
#include "decorator.h"

int main() {
    std::cout << "decorator Mode!" << std::endl;
    ConcreteCake *pConcrete = new ConcreteCake();
    pConcrete->showCake();

    CakeDecoratorMilk *pDecMilk = new CakeDecoratorMilk(pConcrete);
    pDecMilk->showCake();
    CakeDecoratorCholate *pDecCholate = new CakeDecoratorCholate(pConcrete);
    pDecCholate->showCake();

    delete pConcrete;
    delete pDecMilk;
    delete pDecCholate;

    return 0;
}

三、运行结果

相关推荐
学涯乐码堂主40 分钟前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
云栖梦泽1 小时前
Linux内核与驱动:14.SPI子系统
linux·运维·服务器·c++
Gary Studio2 小时前
安卓HAL C++基础-智能指针
开发语言·c++
还是阿落呀2 小时前
基本控制结构2
c++
多思考少编码2 小时前
PAT甲级真题1001 - 1005题详细题解(C++)(个人题解)
c++·python·最短路·pat·算法竞赛
极客智造3 小时前
C++ 标准 IO 流全详解:cin /cout/get /getline 原理、用法、区别与避坑
c++·io
charlie1145141913 小时前
嵌入式C++工程实践第20篇:GPIO 输入模式内部电路 —— 芯片是如何“听“到外部信号的
开发语言·c++·stm32·单片机
Cosolar4 小时前
提示词工程面试题系列 - Zero-Shot Prompting 和 Few-Shot Prompting 的核心区别是什么?
人工智能·设计模式·架构
样例过了就是过了6 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
麦兜和小可的舅舅6 小时前
ClickHouse 列管理机制解析:从 COW、IColumn 到 CRTP
c++·clickhouse