问题:
字节缓冲输出流:BufferedOutputStream(OutputStream out)和字节缓冲输出流:BufferedInputStream(InputStream in)这两种构造方法为什么需要的是字节流,而不是具体的文件或者路径呢?
答:
字节缓冲流仅仅提供缓冲区,而真正的读写数据还得依靠基本的字节流对象进行操作。
1.首先介绍一下BufferedOutputStream的继承
java.lang.Object
java.io.OutputStream
java.io.FilterOutputStream
java.io.BufferedOutputStream
2.可以查看一下BufferedOutputStream的源码:
public BufferedOutputStream(OutputStream out) {
this(out, 8192);
}
这里重写的父类(FilterOutputStream )的构造方法中调用了自己新的多参的构造方法(下图):
public BufferedOutputStream(OutputStream out, int size) {
super(out);
if (size <= 0) {
throw new IllegalArgumentException("Buffer size <= 0");
}
buf = new byte[size];
}
这里是创建一个新的byte类型,大小为8192个字节(说明提供一个这么大的缓冲区)。继续点击super(out)查看到FilterOutputStream类中:
public FilterOutputStream(OutputStream out) {
this.out = out;
}
这里的out将会在FilterOutputStream中下面write和close方法中用到。