简介
装饰模式:动态将职责附加到对象上,若要扩展功能,装饰者提供了比继承更具弹性的代替方案。
优点
不仅可以扩展原有功能,防止类的爆炸式增长
缺点
这种比继承更加灵活机动的特性,也同时意味着更加多的复杂性。装饰模式会导致设计中出现许多小类,如果过度使用,会使程序变得很复杂。
应用场景
1、在不影响其他对象的情况下,以动态、透明的方式给单个对象添加职责。
2、需要动态地给一个对象增加功能,这些功能也可以动态地被撤销。当不能采用继承的方式对系统进行扩充或者采用继承不利于系统扩展和维护时。
代码如下:
#include <iostream>
#include <string>
#include <string.h>
#include <memory>
class phone_base
{
public:
virtual void show_decorate(void) = 0;
};
//小米手机
class xiaomi : public phone_base
{
public:
virtual void show_decorate(void)
{
std::cout << "xiaomi : show_decorate ." << std::endl;
}
};
//华为手机
class huwei : public phone_base
{
public:
virtual void show_decorate(void)
{
std::cout << "huwei : show_decorate ." << std::endl;
}
};
//装饰类
class decorator_phone : public phone_base
{
private:
std::shared_ptr<phone_base> m_phone;
public:
decorator_phone(std::shared_ptr<phone_base> phone): m_phone(phone) {}
virtual void show_decorate() { m_phone->show_decorate(); }
};
//具体的装饰类-挂件
class decorator_phone_pendant : public decorator_phone
{
public:
decorator_phone_pendant(std::shared_ptr<phone_base> phone) : decorator_phone(phone) {}
void show_decorate() { decorator_phone::show_decorate(); add_decorate(); }
private:
void add_decorate() { std::cout << "add pendant ." << std::endl; }
};
//具体的装饰类-贴膜
class decorator_phone_film : public decorator_phone
{
public:
decorator_phone_film(std::shared_ptr<phone_base> phone) : decorator_phone(phone) {}
void show_decorate() { decorator_phone::show_decorate(); add_decorate(); }
private:
void add_decorate() { std::cout << "add film ." << std::endl; }
};
int main()
{
std::cout << "start-up .." << std::endl;
std::shared_ptr<phone_base> phone = std::make_shared<xiaomi>();
std::shared_ptr<phone_base> phone_pendant = std::make_shared<decorator_phone_pendant>(phone);//增加挂件
std::shared_ptr<phone_base> phone_pendant_film = std::make_shared<decorator_phone_film>(phone_pendant);//增加贴膜
phone_pendant_film->show_decorate();
std::cout << "done .." << std::endl;
return 0;
}
代码运行如下: