设计模式_结构型模式_装饰器模式

装饰器模式和代理模式很像。
代理模式是已经知道代理谁了,所以只是对委托类的访问权限进行限制,因此用户只需要访问相应的代理类就可以。装饰器模式并不知道要装饰谁,所以需要传入具体的被装饰对象进行功能的添加

目的:

增加现有类的功能,但是,增加现有类的功能还有一个方法,就是新增加一个子类
添加子类的缺点:功能虽然可以完成,但是代码中有太多的子类添加进来,相同功能的代码大多相同,代码冗余严重
在这里插入图片描述

代码实现

#include<iostream>
#include<mutex>
#include<memory>
#include<unordered_map>
#include<list>
using namespace std;
class Car
{
public:
	virtual void Show() = 0;
};

class Bmw:public Car
{
public:
	void Show()
	{
		cout << "这是一辆宝马汽车:有基本配置" << " ";
	}
};
class Audi :public Car
{
public:
	void Show()
	{
		cout << "这是一辆奥迪汽车:有基本配置" << " ";
	}
};
class Benz :public Car
{
public:
	void Show()
	{
		cout << "这是一辆奔驰汽车:有基本配置" << " ";
	}
};

//装饰器1:定速巡航
class ConcreateDecorator01 :public Car
{
public:
	ConcreateDecorator01(Car*p):pCar(p){}
	void Show()
	{
		pCar->Show();
		cout << "定速巡航" << " ";
	}
private:
	Car* pCar;
};

//装饰器2:自动刹车
class ConcreateDecorator02 :public Car
{
public:
	ConcreateDecorator02(Car* p) :pCar(p) {}
	void Show()
	{
		pCar->Show();
		cout << "自动刹车" << " ";
	}
private:
	Car* pCar;
};
//装饰器3:车道偏离
class ConcreateDecorator03 :public Car
{
public:
	ConcreateDecorator03(Car* p) :pCar(p) {}
	void Show()
	{
		pCar->Show();
		cout << "车道偏离" << " ";
	}
private:
	Car* pCar;
};
int main()
{
	Car* p1 = new ConcreateDecorator01(new Bmw());
	p1= new ConcreateDecorator02(p1);
	p1 = new ConcreateDecorator03(p1);
	p1->Show();
	cout << endl;

	Car* p2 = new Audi();
	p2 = new ConcreateDecorator02(p2);
	p2->Show();
	cout << endl;
	Car* p3 = new Benz();
	p3->Show();
	cout << endl;
	return 0;
}
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值