装饰器模式--学习理解

    装饰器模式:动态的将新功能附加到对象上。在对象扩展方面,它比继承更有弹性,也体现了ocp原则。

    基于面向对象的继承和组合

    解决的问题:例如星穹铁道模拟宇宙的buff叠加问题

    分析:如果考虑所有种类的buff,将其作为boolean类型的成员变量,必然会导致代码急速膨胀,难以维护,且伴随大量if-else.
    如果使用建造者模式,增加一个buff,就进行构建。但是问题是建造模式难以实现动态构建,且产品生产完毕,在想继续修改就需要重新建造。无法满足动态构建的需求。

    如果采用装饰者模式,角色每增加一层buff,就使用装饰者对角色包装一层,显然可以实现动态构建,也能有效避免大量的if-else,但也存在例如有些buff是有持续时间的,到达指定时间,buff如何移除
又是问题,又存在装饰者模式层层封装,导致要访问原始对象就需要层层往下递归。

    当然,我们也要想到,装饰者模式提供的只是一种思路,具体实现肯定不拘泥于这种实现方式

    另外,我们也可以考虑,将所有的buff放入一个ArrayList里面,每增加一个buff就向ArrayList动态添加一个

    实际开发案例,docker镜像基于联合文件系统的层层叠加效果,其内部代码实现肯定也使用了装饰者模式的思想。
  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值