过滤器通过其构造函数与流连接。例如,下面的代码段将缓冲文件data.txt的输入:
InputStream in = new FileInputStream("F:/data.txt"); BufferedInputStream bin = new BufferedInputStream(in);
从文件data.txt中读取文件可能会同时使用 in 和 bin 的read()方法。不过,如果混合调用连接到同一个源的不同流,这可能会违反过滤器流的一些隐含的约定。大多数情况下,应当只使用链中最后一个过滤器进行实际的读/写。要想在编写代码时尽量不带入这种bug,可以有意地重写底层输入流的引用。例如:
InputStream in = new FileInputStream("F:/data.txt"); in = new BufferedInputStream(in);
执行这两行代码后,再没有任何方法能访问底层的文件输入流了,所以也就不会不小心读取这个流而破坏缓冲区。当然了,也可以直接在一个流中构建另一个流,如例:
DataOutputStream dout = new DataOutputStream( new BufferedOutputStream(new FileOutputStream("F:/data.txt")));
有时可能会需要使用链中多个过滤器的方法。不过,除了链中最后一个过滤器之外,无论如何你都不应该从其他的过滤器读取数据,或向其写入任何内容。
我们来看一个完整的例子:
package test; import java.io.BufferedInputStream; import java.io.FileInputStream; import java.io.IOException; public class ReadFile3 { public static void main(String[] args) { try (BufferedInputStream bin = new BufferedInputStream(new FileInputStream("F:/data.txt"))){ int b; while((b = bin.read()) != -1){ System.out.print((char)b); } } catch (IOException e) { e.printStackTrace(); } } }
原文:http://my.oschina.net/fhd/blog/326926