JAVA之IO技术自定义装饰类MybufferedReader
时间:2014-05-03 17:42:26
收藏:0
阅读:258
package ioTest.io2; import java.io.FileReader; import java.io.IOException; /* * 自定义的BufferedReader类 * MyBufferedReaderDemo:也是为了提高对流的操作性能。 * 所以构造函数中应该将流传入 * * --------拓展:装饰设计模式 * 装饰设计模式是28种设计模式之一.目的是为了增强功能. * 将被增强的类A->增强类B * 将A的对象做为参数,传递给B,让B类对A类进行增强。这就是装饰类的基本原理。 * 具体操作时这样,构造函数B(A a) * 这样B类就成了A类的增强类。 * * 显然之前我们学习的BufferedReader,BufferedWriter也同样是增强类。 * BufferedWriter(Writer out) 创建一个使用默认大小输出缓冲区的缓冲字符输出流。 * 因为此类把Writer的对象做为参数,传递给了构造函数。但同时BufferedWriter * 又是Writer的子类。 * * 那么装饰和继承的区别是什么呢?---将在下一个实例中进行分析哦。 * * */ public class MyBufferedReaderDemo { //为了更易扩展,可以写成下面这样。 //就是传递最顶层的父类对象作为参数 Reader r private FileReader r; MyBufferedReaderDemo(FileReader r) { this.r=r; } StringBuilder sBuilder=null; int ch=0; public String MyReadLine() throws IOException { while((ch=r.read())!=-1) { //如何判断读取了一行,对行终止符的处理 if(ch==‘\r‘) continue; if(ch==‘\n‘) return sBuilder.toString(); else sBuilder.append((char)ch); } //上面的操作还存在一点小问题,就是如果读到最后一行没有回车,也就是说没有\n //这时候,只做上面的操作,会丢失掉最后一行数据。所以这时候添加以个判断就OK if(sBuilder.length()>0) return sBuilder.toString(); return null; } public void Myclose() throws IOException { r.close(); } }
//在设计模式栏目下可以找到装饰设计模式的文章哦
评论(0)