1.节点流—文件操作
FileReader类
| 构造方法摘要 | |
|---|---|
| FileReader(File file) | 在给定从中读取数据的 File 的情况下创建一个新 FileReader。 |
| FileReader(FileDescriptor fd) | 在给定从中读取数据的 FileDescriptor 的情况下创建一个新 FileReader。 |
| FileReader(String fileName) | 在给定从中读取数据的文件名的情况下创建一个新 FileReader。 |
FileWriter类
| 构造方法摘要 | |
|---|---|
| FileWriter(File file) | 根据给定的 File 对象构造一个 FileWriter 对象。 |
| FileWriter(File file, boolean append) | 根据给定的 File 对象构造一个 FileWriter 对象。 |
| FileWriter(FileDescriptor fd) | 构造与某个文件描述符相关联的 FileWriter 对象。 |
| FileWriter(String fileName) | 根据给定的文件名构造一个 FileWriter 对象。 |
| FileWriter(String fileName, boolean append) | 根据给定的文件名以及指示是否附加写入数据的 boolean 值来构造 FileWriter 对象。 |
使用FileReader和FileWriter类完成文本文件复制:
import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;public class CopyFile {public static void main(String[] args) throws IOException {//创建输入流对象FileReader fr=new FileReader("C:\\Test\\copyfrom.txt");//文件不存在会抛出java.io.FileNotFoundException//创建输出流对象FileWriter fw=new FileWriter("C:\\Test\\copyto.txt");/*创建输出流做的工作:* 1、调用系统资源创建了一个文件* 2、创建输出流对象* 3、把输出流对象指向文件* *///文本文件复制,一次读一个字符method1(fr, fw);//文本文件复制,一次读一个字符数组method2(fr, fw);fr.close();fw.close();}public static void method1(FileReader fr, FileWriter fw) throws IOException {int ch;while((ch=fr.read())!=-1) {//读数据fw.write(ch);//写数据}fw.flush();}public static void method2(FileReader fr, FileWriter fw) throws IOException {char chs[]=new char[1024];int len=0;while((len=fr.read(chs))!=-1) {//读数据fw.write(chs,0,len);//写数据}fw.flush();}}
2.处理流—缓冲操作
BufferedReader
public classBufferedReaderextends Reader
(1)从字符输入流中读取文本,缓冲各个字符,从而实现字符、数组和行的高效读取。
(2)可以指定缓冲区的大小,或者可使用默认的大小。大多数情况下,默认值就足够大了。
(3)通常,Reader 所作的每个读取请求都会导致对底层字符或字节流进行相应的读取请求。
因此,建议用 BufferedReader 包装所有其 read() 操作可能开销很高的 Reader(如 FileReader 和 InputStreamReader)。
例如,
BufferedReader in = new BufferedReader(new FileReader(“foo.in”));
(4)将缓冲指定文件的输入。如果没有缓冲,则每次调用 read() 或 readLine() 都会导致从文件中读取字节,并将其转换为字符后返回,而这是极其低效的。
BufferedWriter
public class BufferedWriter extends Writer
(1)将文本写入字符输出流,缓冲各个字符,从而提供单个字符、数组和字符串的高效写入。
(2)可以指定缓冲区的大小,或者接受默认的大小。在大多数情况下,默认值就足够大了。
(3)该类提供了 newLine() 方法,它使用平台自己的行分隔符概念,此概念由系统属性 line.separator 定义。并非所有平台都使用新行符 (‘\n’) 来终止各行。因此调用此方法来终止每个输出行要优于直接写入新行符。
(4)通常 Writer 将其输出立即发送到底层字符或字节流。除非要求提示输出,否则建议用 BufferedWriter 包装所有其 write() 操作可能开销很高的 Writer(如 FileWriters 和 OutputStreamWriters)。例如, PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter("foo.out")));
(5)缓冲 PrintWriter 对文件的输出。如果没有缓冲,则每次调用 print() 方法会导致将字符转换为字节,
然后立即写入到文件,而这是极其低效的。 使用BufferedReader和BufferedWriter完成文件复制
import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;public class CopyFile2 {public static void main(String[] args) throws IOException {//创建输入流对象BufferedReader br=new BufferedReader(new FileReader("C:\\Test\\copyfrom.txt"));//文件不存在会抛出java.io.FileNotFoundException//创建输出流对象BufferedWriter bw=new BufferedWriter(new FileWriter("C:\\Test\\copyto.txt"));//文本文件复制char [] chs=new char[1024];int len=0;while((len=br.read(chs))!=-1) {bw.write(chs, 0, len);}//释放资源br.close();bw.close();}}
缓冲区的工作原理:
1、使用了底层流对象从具体设备上获取数据,并将数据存储到缓冲区的数组内。
2、通过缓冲区的read()方法从缓冲区获取具体的字符数据,这样就提高了效率。
3、如果用read方法读取字符数据,并存储到另一个容器中,直到读取到了换行符时,将另一个容器临时存储的数据转成字符串返回,就形成了readLine()功能。
