基于流的装饰设计模式

当想要对已有类的对象进行功能增强时,可以定义一个类,将已有对象传入,基于已有的功能,并提供加强功能。
自定义的类成为装饰类

模仿BufferedReader,对Reader进行包装,体现装饰设计模式

装饰类通常会通过构造方法接受被装饰的对象,并基于被装饰的对象功能,提供更强的功能。
装饰模式比继承灵活,避免继承臃肿,降低了类与类之间的关系

装饰类因为增强已有对象,具备的功能该和已有的功能是相同的,只不过提供了更强的功能,所以装饰类和被装饰类通常都属于一个体系

装饰和继承的区别,可以继承实现,但如果分支太多,继承体系将会非常臃肿,不建议。可以单独提取一个类,对该体系的父类进行该类的构造函数初始化,即可进行操作。即运用多态技术

继承要写共同抽取的,但是不建议写太多,会很臃肿,装饰者模式会很灵活。在维护先人写的代码时候,进行扩展时,装饰者模式会很好,将原对象传入进行操作即可,不会影响原来代码,自己的出现问题,仍可以用原来的代码

例:
MyReader(共同父类)
--MyTextReader
--MyBufferTextReader
--MyMediaReader
--MyBufferMediaReader
--MyDataReader
--MyBufferDataReader

装饰设计
class MyBufferReader{
MyBufferReader(MyReader m){

}
}


package project.test.Thread.Io;

import java.io.*;

/**
* Created by leiming.chen on 2015/6/25.
*/
class MyBufferedReaderDemo {
public static void main(String[] args) throws IOException {
FileReader r = new FileReader("src\\project\\test\\Thread\\Io\\aaa.txt");

MyBufferedReader mb = new MyBufferedReader(r);
String len = "";
while((len=mb.myReadLine())!=null){
System.out.println(len);
}
mb.myClose();
}
}

class MyBufferedReader{
private FileReader r;
public MyBufferedReader(FileReader r){
this.r=r;
}
public String myReadLine(){
StringBuilder sb = new StringBuilder();
int ch;
try {
while ((ch = r.read()) != -1){
if(ch=='\r')
continue;
if(ch=='\n')
return sb.toString();
else
sb.append((char)ch);
}
return null;
}catch (IOException e){
e.printStackTrace();
return null;
}
}
public void myClose(){
try {
r.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值