缓冲的字符流BufferedReader/BufferedWriter
采用缓冲处理是为了提高效率,如果没有缓存,例如FileReader对象,每次调用read()方法进行读操作时,都会直接去文件中读取字节,转换成字符并返回,这样频繁的读取文件效率很低。
缓冲的字符流的出现提高了对流的操作效率,原理就是将数组进行封装。
在使用缓冲的字符流对象时,缓冲的存在是为了增强流的功能
因此在建立缓冲的字符流对象时,要先有流对象的存在。
public BufferedReader(Reader in) ;
public BufferedReader(Reader in, int sz)
public BufferedWriter(Writer out) ;
publicBufferedWriter(Writer out, int sz);
1、 字符缓冲输入流 BufferedReader类
a) BufferedReader的特有方法:public String readLine();//一次读一行,到行标记时,将行标记之前的字符数据作为字符串返回。当读到末尾时,返回null。
2、 字符缓冲输出流 BufferedWriter类
a) BufferedWriter的特有方法:public void newLine();//写出平台相关的行分隔符来标记一行的终止。Windows平台下为’\n’。
注:使用缓冲的字符流时其实就是使用流对象的方法,只不过加入了数组,对数据进行了临时存储,为了提高操作数据的效率。
实例5,缓冲的字符流的使用
import java.io.*;
public class BufferedIODemo {
public static void main(String[] args){
FileWriter fw=null;
BufferedWriter bw=null;
try {
fw=new FileWriter("demo1.txt");
bw=new BufferedWriter(fw);
bw.write("hello");
bw.newLine();
bw.write("java");
bw.newLine();
bw.flush();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
if(bw!=null)
try {
bw.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
装饰设计模式和继承有什么区别?
装饰设计模式比继承有更好的灵活性
实例8,Writer
MediaWriter
TextWriter
需求:想要对数据的操作提高效率,就用到了缓冲技术
Writer
MediaWriter
TextWriter
BufferedWriter
结论:这样就会发现装饰设计模式,优化增强功能的部分。比继承要灵活很多。