关于Java缓冲流的一点误解
Posted hello-mrz
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于Java缓冲流的一点误解相关的知识,希望对你有一定的参考价值。
我在网上看到很多输入流和输出流的代码是这样的:
public class BufferedTest { public static void main(String[] args) { InputStream in = null; OutputStream out = null; try { // 此处为演示效果 将in和out都定义在try块内 防止自动关闭 in = new BufferedInputStream(new FileInputStream("collect.txt")); int count = in.available(); byte[] bytes = new byte[count]; // 通常大家都认为这是为缓冲流定义的缓冲字节数组 if (count > 0) in.read(bytes); // 正常输出,好像也没什么问题,完美的缓冲机制 for (byte b : bytes) System.out.print((char)b); System.out.println(); // 再来看一下输出流 out = new BufferedOutputStream(new FileOutputStream("test.txt")); out.write(bytes); // 奇怪。。test.txt文件是空的 } catch (IOException e) { e.printStackTrace(); } } }
问题就出在byte[] bytes = new byte[count];这行代码定义的并不是缓冲区
在try块内加上一句out.flush(); 冲刷缓冲区,test.txt中的内容就正常了。
缓冲流的缓冲区是在构造器内配置的,默认值时8k
public BufferedInputStream(InputStream in, int size) { super(in); if (size <= 0) { throw new IllegalArgumentException("Buffer size <= 0"); } buf = new byte[size]; }
而read(byte[])和write(byte[])方法是在InputStream和OutputStream中定义的
但是这两个流都是不带缓冲的
输入缓冲区与输出缓冲区的区别
输入:直接从文件读取缓冲区大小的字节,小于默认值时就有多少缓冲多少,程序直接从缓冲区读取字节
输出:只有将缓冲区写满,才输出一次,所以需要flush()方法或close()方法冲刷缓冲区
以上是关于关于Java缓冲流的一点误解的主要内容,如果未能解决你的问题,请参考以下文章
阶段1 语言基础+高级_1-3-Java语言高级_07 缓冲流_4_缓冲流的效率测试_复制文件
java缓冲字符字节输入输出流:java.io.BufferedReaderjava.io.BufferedWriterjava.io.BufferedInputStreamjava.io.(代码片段