在上篇文章中,咱们对IO流做了描述,也拿文本事件做了案例分析,那么对于在IO流中的操作咱们再继续说说看。

再IO流(BufferedInputStream和BufferOutputStream拷贝) 的缓冲思想:1.字节流一次读写一个数组的速度明显比一次读写一个字节的速度快很多;2.这是加入了数组这样的缓冲区效果,java本身在设计的时候;3.也考虑到了这样的设计思想(装饰设计模式后面讲解),所以提供了字节缓冲区流。

先看BufferedInputStream,BufferedInputStream内置了一个缓冲区(数组),从BufferedInputStream中读取一个字节时,BufferedInputStream会一次性从文件中读取8192个, 存在缓冲区中, 返回给程序一个,程序再次读取时, 就不用找文件了, 直接从缓冲区中获取,直到缓冲区中所有的都被使用过, 才重新从文件中读取8192个。

再看BufferedOutputStream,BufferedOutputStream也内置了一个缓冲区(数组), 程序向流中写出字节时, 不会直接写到文件, 先写到缓冲区中,直到缓冲区写满, BufferedOutputStream才会把缓冲区中的数据一次性写到文件里。

我们拿个例子来说明:

//创建文件输入流对象,关联小跳蛙.mp3
FileInputStream fis = new FileInputStream("小跳蛙.mp3");
//创建缓冲区对fis装饰
BufferedInputStream bis = new BufferedInputStream(fis);
//创建输出流对象,关联copy.mp3
FileOutputStream fos = new FileOutputStream("copy.mp3");
//创建缓冲区对fos装饰
BufferedOutputStream bos = new BufferedOutputStream(fos);
int b;
while((b = bis.read()) != -1) {
bos.write(b);
}
//只关装饰后的对象即可
bis.close();
bos.close();

对于小数组的读写和带Buffered的读取哪个更快呢?定义小数组如果是8192个字节大小和Buffered比较的话; 定义小数组会略胜一筹,因为读和写操作的是同一个数组,而Buffered操作的是两个数组。

对于IO流中flush和close方法的区别

flush()方法:用来刷新缓冲区的,刷新后可以再次写出 。

close()方法:用来关闭流释放资源的的,如果是带缓冲区的流对象的close()方法,不但会关闭流,还会再关闭流之前刷新缓冲区,关闭后不能再写出。

字节流读取中文的问题:字节流在读中文的时候有可能会读到半个中文,造成乱码。

字节流写出中文的问题:字节流直接操作的字节,所以写出中文必须将字符串转换成字节数组,写出回车换行 write("\r\n".getBytes())。