昨天谈了字符流的怎么拷贝文件,特别是以FileReader和FileWritter来实现文数据的复制为例说明了字符数据的读写功能,我们谈了在实现字符数据拷贝的时候使用的两种方法,一种是read()一次读取一个文件,和read(char []cbuf,int offset, int length)一次读取字符数组的一部分。第二种方式虽然提高了效率,但是对于系统底层的资源来说还是要不断的做读写的切换操作,效率也不够高。而Java针对这种情况,给我们提供一种技术:字符流缓冲区技术
缓冲区的出现提高了对数据的读写效,缓冲区下面也对应两个类:BufferedReader,BufferedWriter,当然缓冲区不是和字符流隔开独立存在的,需要和流结合才能使用,只是在流的基础上对流的功能进行了增强。特别是BufferedReader下面有一个方法,readLine()方法,可以实现一行一行的读取,当读取到文件末尾处会返回null。
readLine()方法的原理:无论是读取一行,还是获取多个字符。其实最终都是在硬盘上一个一个的读取。只是readLine由于字符缓冲区内部有一个封装好的数组,当读取到的字符时它会先存到内置的数组中,当读取到Windows环境下的回车符\r\n时,就会将数组中的数据变成字符串返回出去!
package com.io.com;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
/**
* 通过缓冲区复制一个.java文件。
*
*/
public class CopyTextByBuf {
public static void main(String[] args) {
//创建对象引用
BufferedReader bufr=null;
BufferedWriter bufw =null;
try {
// 创建字符读写流缓冲区对象,传入参数为字符流对象
bufr =new BufferedReader(new FileReader("FileReaderDemo1.java"));
bufw = new BufferedWriter(new FileWriter("buf.txt"));
String len =null;
while ((len=bufr.readLine())!=null) {
bufw.write(len);
bufw.newLine();
bufw.flush();
}
} catch (IOException e) {
throw new RuntimeException("文件读取失败!");
}
finally{
try {
if (bufr!=null) {
bufr.close();
}
} catch (Exception e2) {
throw new RuntimeException("读取关闭失败!");
}
try {
if (bufw!=null) {
bufw.close();
}
} catch (Exception e2) {
throw new RuntimeException("写入关闭失败!");
}
}
}
}