设计模式(十一)结构型模式-装饰模式decorator

装饰模式是一种设计模式,用于在不修改原有对象的基础上,通过附加新的职责来扩展对象功能。它通过对象关联而非继承来实现扩展,避免了类爆炸问题。在Java IO流、Swing组件和Servlet API中广泛应用。装饰模式提供了灵活性,可以按需组合不同装饰以实现不同功能,但同时也可能产生大量小对象,调试复杂。相比于桥接模式,装饰模式侧重于增加新功能。
摘要由CSDN通过智能技术生成

•职责:

— 动态的为一个对象增加新的功能。

— 装饰模式是一种用于代替继承的技术,无须通过继承增加子类就能拓展对象的新功能。使用对象的关联关系代替继承关系,更加灵活,同时避免类型体系的快速膨胀

• 实现细节:

– Component抽象构件角色:

• 真实对象和装饰对象有相同的接口。这样,客户端对象就能够以与真实对象相同的方式同装饰对象交互。

– ConcreteComponent 具体构件角色(真实对象):

• io流中的FileInputStream、FileOutputStream

– Decorator装饰角色:

• 持有一个抽象构件的引用。装饰对象接受所有客户端的请求,并把这些请求转发给真实的对象。这样,就能在真实对象调用前后增加新的功能。

– ConcreteDecorator具体装饰角色:

• 负责给构件对象增加新的责任。

• 简单案例说明

车===》增加翅膀,飞行汽车===》增加浮沉箱,水上汽车===》增加人工智能,自动驾驶,汽车人

• 开发中使用的场景:

– IO中输入流和输出流的设计

– Swing包中图形界面构件功能

– Servlet API 中提供了一个request对象的Decorator设计模式的默认实现类HttpServletRequestWrapper,HttpServletRequestWrapper类,增强了request对象的功能。

– Struts2中,request,response,session对象的处理

• IO流实现细节:

– Component抽象构件角色:

• io流中的InputStream、OutputStream、Reader、Writer

– ConcreteComponent 具体构件角色:

• io流中的FileInputStream、FileOutputStream

– Decorator装饰角色:

• 持有一个抽象构件的引用:io流中的FilterInputStream、FilterOutputStream

– ConcreteDecorator具体装饰角色:

• 负责给构件对象增加新的责任。Io流中的BufferedOutputStream、BufferedInputStream等。

• 总结:

– 装饰模式(Decorator)也叫包装器模式(Wrapper)

– 装饰模式降低系统的耦合度,可以动态的增加或删除对象的职责,并使得需要装饰的具体构建类和具体装饰类可以独立变化,以便增加新的具体构建类和具体装饰类。

• 优点

– 扩展对象功能,比继承灵活,不会导致类个数急剧增加

– 可以对一个对象进行多次装饰,创造出不同行为的组合,得到功能更加强大的对象

– 具体构建类和具体装饰类可以独立变化,用户可以根据需要自己增加新的具体构件子类和具体装饰子类。

• 缺点

– 产生很多小对象。大量小对象占据内存,一定程度上影响性能。

– 装饰模式易于出错,调试排查比较麻烦。

• 装饰模式和桥接模式的区别:

– 两个模式都是为了解决过多子类对象问题。但他们の诱因不一样。桥模式是对象自身现有机制沿着多个维度变化,是既有部分不稳定。装饰模式是为了增加新的功能。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

plenilune-望月

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值