首页 > 代码库 > JAVA之IO技术自定义装饰类MybufferedReader

JAVA之IO技术自定义装饰类MybufferedReader

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();
	}
}
//在设计模式栏目下可以找到装饰设计模式的文章哦