黑马程序员技术交流社区
标题:
关于IO流的自定义装饰类
[打印本页]
作者:
蓝枫
时间:
2014-3-30 15:34
标题:
关于IO流的自定义装饰类
import java.io.*;
class MyBufferedReader extends Reader
{
private Reader r;
MyBufferedReader(Reader r)
{
this.r = r;
}
//可以一次读一行数据的方法
public String MyReaderLine()throws IOException
{
//定义一个临时容器,原BufferReader封装的是字符数组
//为了演示方便,定义一个StringBuilder容器,因为最终
//还是要将数据变成字符串
StringBuilder sb = new StringBuilder();
int ch = 0;
while((ch=r.read())!=-1)
{
if(ch=='\r')
continue;
if(ch=='\n')
return sb.toString();
else
sb.append((char)ch);
}
if(sb.length()!=0)
return sb.toString();
return null;
}
/*
覆盖Reader类中的抽象方法
*/
public void close()throws IOException
{
r.close();
}
public int read(char[] cbuf,int off,int len)throws IOException
{
return r.read(cbuf,off,len);
}
public void myClose()throws IOException
{
r.close();
}
}
class MyBufferedReaderDemo
{
public static void main(String[] args)throws IOException
{
FileReader fr = new FileReader("Demo.txt");
MyBufferedReader myBuf = new MyBufferedReader(fr);
String line = null;
while((line=myBuf.MyReaderLine())!=null)
{
System.out.println(line);
}
myBuf.myClose();
}
}
复制代码
自定义装饰类为什么要覆盖Reader类中的抽象方法?
作者:
osully
时间:
2014-3-30 15:38
因为父类此方法是抽象的,
如果不去复写,那么子类也是一个抽象类
作者:
汗血黑马
时间:
2014-3-30 20:30
装饰设计模式都是在已有的类的发展过程中优化得来的,就是当想要对已有的对象进行功能增强时,可以定义类,将已有对象传入,基于已有的功能,并提供加强功能,那么自定义的该类成为装饰类。
作者:
lazy_xia
时间:
2014-3-31 14:34
父类有抽象方法那父类就是抽象的含有抽象方法的函数式不能被实例化的不是接口的话 可以用集成来 是接口的话就实现它 集成要是你不复写父类的抽象方法那你子类就等于也含有一个抽象方法不过在父类里也就是说你子类也不能够被实例化 也就是个抽象类
我是这么理解的 不知道啊能帮到你
作者:
zhangbingyuan
时间:
2014-3-31 14:50
本帖最后由 zhangbingyuan 于 2014-3-31 14:52 编辑
Reader类用于读取字符流的抽象类。子类必须实现 read(char[], int, int) 和 close()两个方法。这是我查阅jdk1.6 API文档时候的原话。 具体实现这两个方法的时候,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。
自定义装饰类也是继承于Reader抽象类,所以,必须实现上述的两个方法才能建立实例对象。
作者:
枫儿
时间:
2014-4-6 19:37
楼主你好,如果问题已解决,请将帖子改为提问结束,如果没有解决请楼主继续提问,谢谢合作
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2