今天继续学习一种叫做装饰器模式的设计模式。
当相对已有的对象进行功能增强时,可以定义类,将已有对象传入,基于已有功能,提供加强功能。自定义的类称为装饰类
装饰类通常通过构造器接收被装饰的对象,并基于被装饰对象的功能,提供更强的功能
简单点说,就是这种模式是将已有对象的功能增强,并且以原对象已有的功能方法制作增强方法。好像越说越复杂了!!
比如,我们知道系统内置的BufferedReader类,是一个带缓冲的输入流,并且可以包装其他的节点流 ,它提供了一个readLine()方法,去提高效率,其实Reader是自带缓冲区的,默认是1024*8,即8192byte,而且不能改变,当多读一个字节时,缓冲区就会自动关闭,而BuffferedReader它提供的缓冲区是可以自定义的。
看代码吧:
自定义一个和BufferedReader功能一样的类:
class MyBufferedReader{
private Reader r;
public MyBufferedReader(Reader r){
this.r = r;
}
//以下来模拟readLine()方法
public String readLine()throws Exception{
StringBuffer sbr = new StringBuffer();
int ch ;
while(true){
ch = r.read();
if(ch == '\n') break;//读到行末就break
if(ch == '\r') continue;//\r回到行首
if(ch == -1) break;
sbr.append((char)ch);
}
return sb.length() == 0 ? null : sb.toString();
}
public void close() throws Exception{
r.close();
}
}
public class Test{
public static void main(String args[]){
try{
Reader in = new FileReader("E:/a.txt");
MyBufferedReader mbr = new MyBufferedReader(in);
try{
String line;
while((line=mbr.readLine()) != null){
System.out.println(line);
}
}finally{
mbr.close();
}
}catch(Exception e){
e.printStackTrace();
}
}
}
这里要提一下,main方法里try-catch-finally的写法:
更合理写法:
public class Test{
public static void main(String[] args){
try{
Reader r = new FileReader("E:/a.txt");
// 当这里有异常时(a.txt文件找不到),下面的try-finally就不会执行
//也就是说,流没有打开,是没有必要关闭流的;
//这种写法更合理些
try{
//这里操作数据;
}finally{
//close()写在这里
}
}catch(Exception e){
e.printStackTrace();
}
}
}
再看下面的写法:
较不合理写法:
public class Test{
public static void main(String[] args){
try{
Reader r = new FileReader("E:/a.txt");
//如果这里没有找到a.txt文件,其实就没有必须再去关闭流了,
//而这种写法里,不管怎么样,最后总是去关闭流,这是不合理的
}catch(Exception e){
e.printStackTrace();
}finally{
//close()写在这里;
}
}
}
先写到这里,水平有限,多多指教。
版权声明:本文为博主原创文章,未经博主允许不得转载。