流之过滤器流(介绍)

InputStream和OutputStream是相当原始的类。它们可以单个或成组地读/写字节,但仅此而已。要确定这些字节的含义,这完全由程序员和代码来完成。不过,有一些极为常见的数据格式,如果在类库中提供这些数据格式的固定实现会很有好处。例如,许多作为网络协议一部分传递的整数是32位big-endian整数。许多通过web发送的文本是7位ASCII、8位Latin-1或多字节UTF-8。许多由FTP传输的文件存储为zip格式。Java提供了很多过滤器类,可以附加到原始流中,在原始字节和各种格式之间来回转换

过滤器有两个版本过滤器流以及阅读器和书写器过滤器流仍然主要将原始数据作为字节处理,例如通过压缩数据或解释为二进制数字。阅读器和书写器处理多种编码文本的特殊情况,如UTF-8和ISO 8859-1。

过滤器以的形式进行组织,如下图:

流之过滤器流(介绍)

上图中,链中的每个环节都接收前一个过滤器或流的数据,并把数据传递给链中的下一个环节。在这个示例中,从本地网络接口接收到一个压缩的加密文本文件,在这里本地代码将这个文件表示为TelnetInputStream。通过一个BufferedInputStream缓冲这个数据来加速整个过程。由一个CipherInputStream将数据解密。再由一个GZIPInputStream解压解密后的数据。一个InputStreamReader将解压后的数据转换为Unicode文本。最后,文本由应用程序读取并处理。

你可能感兴趣的:(java-IO与网络编程)