HeadFirst设计模式-装饰者模式(下)

本文探讨了Java I/O系统如何利用装饰者模式来扩展输入流的功能,例如BufferedInputStream和LineNumberInputStream。装饰者模式允许在不修改原有代码的情况下增加行为,但也可能导致大量小类的出现,增加了API使用的复杂性。总结了装饰者模式的关键点,包括其动态扩展、透明性和可能带来的类爆炸问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

接上文。

真实世界的装饰者:Java I/O

java.io包内的类太多了,简直是排山倒海。现在,你已经知道装饰者模式,这些I/O的相关类对你来说应该更有意义了,因为其中许多类都是装饰者。

例如:

BufferedInputStream及LineNumberInputStream都扩展自FilterInputStream,而FilterInputStream是一个抽象的装饰类。

而FileInputStream和FilterInputStream都扩展自InputSteam类,InputSteam也是个装饰类。

java.io组合各种输入流装饰者来符合你的用途。

但是Java I/O也引出装饰者模式的一个“缺点”:利用装饰者模式,常常造成设计中有大量的小类,数量实在太多,可能会造成使用此API程序员的困扰。

小结

1、继承属于扩展形式之一,但不见得是达到弹性设计的最佳方式。

2、在我们的设计中,应该允许行为可以被扩展,而无需修改现有的代码。

3、组合和委托可用于在运行时动态地加上新的行为。

4、除了继承,装饰者模式也可以让我们扩展行为。

5、装饰者模式意味着一群装饰者类,这些类用来报装具体组件。

6、装饰者类反映出被装饰的组件类型。事实上,他们具有相同的类型,都经过接口或继承实现。

7、装饰者可以在被装饰者的行为前面或者后面加上自己的行为,甚至将被装饰者的行为整个取代掉,而达到特定的目的。

8、你可以用无数个装饰者包装一个组件。

9、装饰者一般对组件的客户是透明的,除非客户程序依赖于组件的具体类型。

10、装饰者会导致设计中出现许多小对象,如果过度使用,会让程序变得很复杂。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值