要检索通过gzip压缩的文件的未压缩大小,可以读取最后四个字节。我这样做是为了看看是否有任何文件不是它们应该有的大小。如果一个文件比它应该的小,我将使用下面的代码追加到该文件中:
GZIPOutputStream gzipoutput = new GZIPOutputStream
(new FileOutputStream(file, true));
while ((len=bs.read(buf)) >= 0) {
gzipoutput.write(buf, 0, len);
}
gzipoutput.finish();
gzipoutput.close();当然,这会按预期的方式追加到gzip文件的末尾。但是,在追加之后,读取gzip文件的最后四个字节(以获得未压缩的文件大小)并没有给出预期的结果。我怀疑这是因为使用GZIPOutputStream不能正确地将大小字节追加到文件的末尾。
如何修改代码以便追加正确的大小字节?
编辑
我正在按小字节的顺序读取字节,如下所示:
gzipReader.seek(gzipReader.length() - 4);
int byteFour = gzipReader.read();
int byteThree = gzipReader.read();
int byteTwo = gzipReader.read();
int byteOne = gzipReader.read();
// Now combine them in little endian
long size = ((long)byteOne << 24) | ((long)byteTwo << 16) | ((long)byteThree << 8) | ((long)byteFour);我在想,由于我是附加到一个gzip文件中,它只编写附加的字节,而不是文件的总大小。这可信吗?
发布于 2014-08-21 23:44:20
因为我是附加到gzip文件中,所以它只编写附加的字节,而不是文件的总大小。这可信吗?
不仅似是而非,而且不可避免。看看你的代码。附加的GZIPOutputStream将如何确切地知道文件的前一个大小?它所能看到的只有传入数据和传出的OutputStream.。
https://stackoverflow.com/questions/25436895
复制相似问题