昨天谈了字符流的怎么拷贝文件,特别是以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("写入关闭失败!"); } } } }