我使用这段代码创建一个包含文件列表的.zip文件:
我不知道zip算法和ZipOutputStream是如何工作的,如果在读取并将所有数据发送到“zos”之前它写入了一些内容,那么结果文件的大小可能会与选择另一个缓冲区大小时不同。
换句话说,我不知道算法是否是这样的:
读取数据-->处理数据-->创建 .ZIP
还是:
读取数据块-->处理数据块-->将数据块写入 .ZIP-->| ^---------------------------------------------------|
如果是这种情况,最佳的缓冲区大小是多少?
更新:
我已经测试了这段代码,将缓冲区大小从1024更改为64,并压缩相同的文件:使用1024字节时,80 KB的结果文件比使用64字节缓冲区小3个字节。哪种缓冲区大小可以在最短时间内生成最小的 .zip 文件?
ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(zipFile));
for (int i=0;i<srcFiles.length;i++){
String fileName=srcFiles[i].getName();
ZipEntry zipEntry = new ZipEntry(fileName);
zos.putNextEntry(zipEntry);
InputStream fis = new FileInputStream(srcFiles[i]);
int read;
for(byte[] buffer=new byte[1024];(read=fis.read(buffer))>0;){
zos.write(buffer,0,read);
}
fis.close();
zos.closeEntry();
}
zos.close();
我不知道zip算法和ZipOutputStream是如何工作的,如果在读取并将所有数据发送到“zos”之前它写入了一些内容,那么结果文件的大小可能会与选择另一个缓冲区大小时不同。
换句话说,我不知道算法是否是这样的:
读取数据-->处理数据-->创建 .ZIP
还是:
读取数据块-->处理数据块-->将数据块写入 .ZIP-->| ^---------------------------------------------------|
如果是这种情况,最佳的缓冲区大小是多少?
更新:
我已经测试了这段代码,将缓冲区大小从1024更改为64,并压缩相同的文件:使用1024字节时,80 KB的结果文件比使用64字节缓冲区小3个字节。哪种缓冲区大小可以在最短时间内生成最小的 .zip 文件?