引言
我们对于日志的保存,如果需要存档,那么最好的方式就是对日志文件进行压缩。压缩可以减少资源占用,在需要的时候还能回溯查找。在本篇博文中,详细介绍基于字节流的压缩方式,着重介绍ZipOutputStream、ZipInputStream文件的压缩和解压方式,同时介绍CheckedInputStream、CheckedOutputStream的校验方式,在最后给出相应的demo供大家参考。笔者目前整理的一些blog针对面试都是超高频出现的。大家可以点击链接:http://blog.csdn.net/u012403290
源码在JDK的位置
文件压缩其实本质上也是属于IO操作,但是在JDK中并没有把这部分相关的流操作写入java.io包中。我们需要在java的工具包中:java.util.zip中找到他们:
在本篇博文中就是对zip下的一些核心类进行介绍。其中已Stream结尾的就是涉及的IO字节流相关的类。
压缩家族结构
我们在起初介绍IO系统的时候给出了一个IO系统的结构图。就是下面这张:
其实在中间省略了一些流(因为并不常见),在这里补充一下涉及到文件压缩和文件一致性的相关流:
首先,文件压缩都是针对字节流的,所以在FilterInputStream装饰器下还存在相关的两个子类:CheckedInputStream与DeflaterInputStream,前者是用于保证文件在传输过程与存储过程中记录一个校验和(checksum)的值来保证数据的完整性,后者是压缩类的基类。相应的在FilterOutputStream装饰器下还存在两个对应相关的子类:CheckedOutputStream和DeflaterOutputStream类,功能和前面介绍的是一样的。在FileterInputStream和FilterOutputStream下存在着所有压缩的子类:zip压缩方式与Gzip压缩方式。图解它们之间的关系如下:
OutputStream:
InputStream:
值得一提的是,文件压缩是面向字节流的(已Stream结尾的类),但是如果在针对字符流的时候(reader和writer)我们需要用InputStreamReader和OutputStreamWriter进行转化。比如说如下:
BufferedReader reader = new BufferedReader(new InputStreamReader(new GZIPInputStream(new FileInputStream("filePath&#