设计模式:装饰器模式

装饰器模式

装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它是作为现有的类的一个包装。

这种模式创建了一个装饰类,用来包装原有的类,并在保持类方法签名完整性的前提下,提供了额外的功能。

意图

动态地给一个对象添加一些额外的职责。就增加功能来说,装饰器模式相比生成子类更为灵活。

主要解决

一般的,我们为了扩展一个类经常使用继承方式实现,由于继承为类引入静态特征,并且随着扩展功能的增多,子类会很膨胀。
在不想增加很多子类的情况下扩展类。

如何解决

原有一台类的继承体系,我们想给这个类做功能扩充,再不添加新的子类和修改父类的情况下,我们可以将新的扩充功能进行划分,每一类扩充当成一个新的装饰器类。
该装饰器类中包含一个源继承体系的基类指针,可以使用这个指针对原有继承体系的对象进行扩展功能的操作。main()函数内部只需要声明装饰器类即可。
这样原有的继承体系不变,继续维持基本的继承关系。装饰器体系保存继承体系的基类指针,可以操作继承体系内的对象,并做扩展操作。对类的扩展和原有的逻辑做了分离。

优点

装饰类和被装饰类可以独立发展,不会相互耦合,装饰模式是继承的一个替代模式,装饰模式可以动态扩展一个实现类的功能。

缺点

多层装饰比较复杂。

注意事项:可代替继承

桥模式

装饰器模式和桥模式都是为了解决类的功能扩展问题(以及因此导致的子类过多的问题)。
主要区别是:
装饰器模式基础类本身不变,我们为了扩展创建一个新的类,通过组合调用的形式来对已经存在的基础类进行一层封装,调用的话也是使用新的类的指针。
桥模式基础类是发生变化的,为了扩展我们会在基础类中创建一个扩展类的指针,用扩展类进行功能扩展。调用的话使用的是基础类的指针

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值