为什么是装饰模式而不是继承

本文对比了使用继承和装饰模式实现Java IO流的不同方案。通过装饰模式可以更灵活地为现有类添加新功能,避免了因多种组合需求而产生的大量子类。

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

对于java IO而言

对于是否需要缓存算一个需求的话(两种情况),读取的流的类型是了另一个需求(两种情况),输入还是输出又是一个需求如果采用继承的话(两种情况),需要的类有:
带缓存/字节型/输入流;
带缓存/字节型/输出流;
带缓存/字符型/输入流;
带缓存/字符型/输出流;
不带缓存/字节型/输入流;
不带缓存/字节型/输出流;
不带缓存/字符型/输入流;
不带缓存/字符型/输出流;
这里只考虑了几情况已经需要继承的类的数量已经开始变得非常大(实际上,数量是每方面的可能相乘,2*2*2)。

如果采用装饰模式,一旦你觉得需要增加一个功能,那你只需要将现有的类作为参数传入到构造函数就行:

File file=new File("/home/lxx/test");
FileInputStream fi=new FileInputStream(file);
//这时候,你认为需要一个带缓存的文件输入流
BufferedInputStream bis=new BufferedInputStream(fi);

也就是说,不再需要对所有的类型进行组合,而是对每种单方面的类型创造一个类就可以。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值