1.
按照流向分:输入流;输出流
2.
按照处理数据的单位分:字节流
(8
位的字节
)
;字符流
(16
位的字节
).
2.2什么是输入输出流
输入
就是将数据从各种输入设备(包括文件、键盘等)中读取到内存中。
输出
则正好相反,是将数据写入到各种输出设备(比如文件、显示器、磁盘等)。
例如键盘就是一个标准的输入设备,而显示器就是一个标准的输出设备,
但是文件既可以作为输入设
备,又可以作为输出设备。
?2.3?什么是字节流,字符流
File
类不支持文件内容处理,如果要处理文件内容,必须要通过流的操作模式来完成。
在
java.io
包中,流分为两种:字节流与字符流
字节流:数据流中最小的数据单元是字节 。
InputStream
、
OutputStream
字符流:数据流中最小的数据单元是字符,
Java
中的字符是
Unicode
编码,一个字符占用两个字节
。
Reader
、
Writer.
Java
中
IO
流的体系结构如图
2.4 字节流
FileInputStream
从文件系统中的某个文件中获得输入字节。
FileInputStream
用于读取诸如图像数据之类的原始字节流。
文件输出流是用于将数据写入到输出流
File
或一个
FileDescriptor
。 文件是否可用或可能被
创建取决于底层平台。
特别是某些平台允许一次只能打开一个文件来写入一个
FileOutputStream
(或其他文件写入对
象)。 在这种情况下,如果所涉及的文件已经打开,则此类中的构造函数将失败。
问题一:为什么需要有缓冲流?
答:当我们用
read()
读取文件时,每读一个字节,访问一次硬盘,效率很低 。文件过大时,操作
起来也不是很方便。因此我们需要用到
buffffer
缓存流,
当创建
buffffer
对象时,会创建一个缓冲区
数组。
当我们读一个文件时,先从硬盘中读到缓冲区,然后直接从缓冲区输出即可,效率会更
高。
BufferedInputStream
为另一个输入流添加了功能,即缓冲输入和支持
mark
和
reset
方法的功
能。 当创建
BufferedInputStream
时,将创建一个内部缓冲区数组。
当从流中读取或跳过字节时,内部缓冲区将根据需要从所包含的输入流中重新填充,一次有多个字
节。
mark
操作会记住输入流中的一点,并且
reset
操作会导致从最近的
mark
操作之后读取的所
有字节在从包含的输入流中取出新的字节之前重新读取。
该类实现缓冲输出流。 通过设置这样的输出流,应用程序可以向底层输出流写入字节,而不必为
写入的每个字节导致底层系统的调用。
示例使用 BufferedInputStream 和 BufferedOutputStream 实现文件拷贝:
import java.io.*;
public class TestBufferStreamCopy {
? ?public static void main(String[] args) throws IOException {
? ? ? ?File file=new File("bit.txt");
? ? ? ?if(!file.isFile()){ ? return; ? }
? ? ? ?BufferedInputStream bfis=new BufferedInputStream(new
FileInputStream(file));
? ? ? ?BufferedOutputStream ?bfos=new BufferedOutputStream(new
FileOutputStream("src\\"+file.getName()));//copy到src目录下
? ? ? ?byte bytes[]=new byte[1024];
? ? ? ?int temp=0; ? ? ?//边读边写
? ? ? ?while ((temp=bfis.read(bytes))!=-1){//读
? ? ? ? ? ?bfos.write(bytes,0,temp); ? //写
? ? ? }
? ? ? ?bfos.flush();
? ? ? ?bfos.close();
? ? ? ?bfis.close();
? ? ? ?System.out.println("copy成功!");
? }
}
?有无缓冲效率的对比(以读为例)
import java.io.*;
public class BufferByte {
? ?public static void main(String[] args) throws IOException {
? ? ? ?//bit.txt 大小大约为1500KB
? ? ? ?File file=new File("bit.txt");
? ? ? ?//缓冲流
? ? ? ?BufferedInputStream bfis=new BufferedInputStream(new
FileInputStream(file));
? ? ? ?int temp=0;
? ? ? ?long time=System.currentTimeMillis();//获取当前时间至1970-1-1的毫秒数
? ? ? ?while ((temp=bfis.read())!=-1){
? ? ? ? ? ?//System.out.print((char) temp);
}
? ? ? ?time=System.currentTimeMillis()-time;
? ? ? ?bfis.close();
? ? ? ?System.out.println("缓冲流读:"+time+"ms");
? ? ? ?//非缓冲
? ? ? ?FileInputStream fis=new FileInputStream(file);
? ? ? ?temp=0;
? ? ? ?time=System.currentTimeMillis();
? ? ? ?while ((temp=fis.read())!=-1){
? ? ? ? ? ?//System.out.print((char) temp);
? ? ? }
? ? ? ?time=System.currentTimeMillis()-time;
? ? ? ?fis.close();
? ? ? ?System.out.println("非缓冲区读:"+time+"ms");
? }
}
结果输出:

三:字符流
3.1?字符流 FileReader 和 FileWriter
如果要从文件中读取内容,可以直接使用
FileReader
子类。
FileReader
是用于读取字符流。 要读取原始字节流,请考虑使用
FileInputStream
。
如果是向文件中写入内容,应该使用
FileWriter
子类
FileWriter
是用于写入字符流。 要编写原始字节流,请考虑使用
FileOutputStream
?示例使用 FileReader 和 FileWriter 复制文件:
public class CopyFileDemo {
public static void main(String[] args) throws IOException {
方法 解释
BufferedReader(Reader in) 创建使用默认大小的输入缓冲区的缓冲字符输入
流。
BufferedReader(Reader in, int
sz)
创建使用指定大小的输入缓冲区的缓冲字符输入
流。
方法 解释
BufferedWriter(Writer out) 创建使用默认大小的输出缓冲区的缓冲字符输出流。
BufferedWriter(Writer out, int
sz)
创建一个新的缓冲字符输出流,使用给定大小的输出缓
冲区。
2、字符缓冲流 BufferedReader 和 BufferedWriter
为了提高字符流读写的效率,引入了缓冲机制,进行字符批量的读写,提高了单个字符读写的效率。
BufferedReader 用于加快读取字符的速度, BufferedWriter 用于加快写入的速度。
BufferedReader 和 BufferedWriter 类各拥有 8192个 字符的缓冲区。当 BufferedReader在 读取文
本文件时,会先尽量从文件中读入字符数据并放满缓冲区,而之后若使用read()方法,会先从缓冲区中
进行读取。如果缓冲区数据不足,才会再从文件中读取,使用 BufferedWriter 时,写入的数据并不会
先输出到目的地,而是先存储至缓冲区中。如果缓冲区中的数据满了,才会一次对目的地进行写出。
从字符输入流读取文本,缓冲字符,以提供字符,数组和行的高效读取
将文本写入字符输出流,缓冲字符,以提供单个字符,数组和字符串的高效写入。
示例使用 BufferedReader 和 BufferedWriter 进行文件拷贝
//创建输入流对象
FileReader fr = new FileReader("E:\\bit\\bitSrc.java");
//创建输出流对象
FileWriter fw = new FileWriter("E:\\bit\\bitCopy.java");
//读写数据
int ch;
while((ch=fr.read())!=-1) {
fw.write(ch);
}
//释放资源
fw.close();
fr.close();
}
?3.2?、字符缓冲流 BufferedReader 和 BufferedWriter
为了提高字符流读写的效率,引入了缓冲机制,进行字符批量的读写,提高了单个字符读写的效率。
BufferedReader
用于加快读取字符的速度,
BufferedWriter
用于加快写入的速度。
BufferedReader
和
BufferedWriter
类各拥有
8192
个
字符的缓冲区。当
BufferedReader
在
读取文
本文件时,会先尽量从文件中读入字符数据并放满缓冲区,而之后若使用
read()
方法,会先从缓冲区中
进行读取。如果缓冲区数据不足,才会再从文件中读取,使用
BufferedWriter
时,写入的数据并不会
先输出到目的地,而是先存储至缓冲区中。如果缓冲区中的数据满了,才会一次对目的地进行写出。
从字符输入流读取文本,缓冲字符,以提供字符,数组和行的高效读取
将文本写入字符输出流,缓冲字符,以提供单个字符,数组和字符串的高效写入。

示例使用 BufferedReader 和 BufferedWriter 进行文件拷贝 ?
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class FileWrite {
public static void main(String[] args) throws IOException {
FileReader reader=new FileReader("E:\\BIT\\bit.txt");
BufferedReader bReader=new BufferedReader(reader);
FileWriter writer=new FileWriter(":\\BIT\\bit2.txt");
BufferedWriter bWriter=new BufferedWriter(writer);
String content="";
//readLine一行一行的读取
while((content=bReader.readLine())!=null){
//\r\n换行
bWriter.write(content+"\r\n");
}
/**
?* 关闭流的顺序:
?* 当A依赖B的时候先关闭A,再关闭B
?* 带缓冲的流最后关闭的时候会执行一次flush
?*/
reader.close();
bReader.close();
bWriter.close();
writer.close();
}
}
四:字节流对比字符流
1
、字节流操作的基本单元是字节;字符流操作的基本单元为
Unicode
码元。
2
、字节流在操作的时候本身不会用到缓冲区的,是与文件本身直接操作的;而字符流在操作的时候使
用到缓冲区的。
3
、所有文件的存储都是字节
(byte)
的存储,在磁盘上保留的是字节。
4
、在使用字节流操作中,即使没有关闭资源(
close
方法),也能输出;而字符流不使用
close
方法的
话,不会输出任何内容。
总结:
? ?码文不易,大家多多支持,望不吝赐教,感激不尽!越来越好!!!