我正在尝试解压缩一个大小约为1GB的大文件,无法使用文件输出流方法。我的最后一个文档需要解压缩文件的字节数组来创建一个新文件。目前,我一直在手动增加每次读取的数组大小。但是这对于大文件来说太慢了。有什么办法可以让我用这种方法提高效率吗。
if (primaryDocumentInputStream != null) {
byte[] tempbuffer = new byte[536870912];
byte[] mainbuffer = new byte[536870912];
int lenMainBuffer = 0;
try {
int aIntBuffer = aGZIPInputStream.read(tempbuffer);
while (aIntBuffer > 0) {
byte[] copyBuffer = new byte[lenMainBuffer + aIntBuffer];
System.arraycopy(mainbuffer, 0, copyBuffer, 0, lenMainBuffer);
System.arraycopy(tempbuffer, 0, copyBuffer, lenMainBuffer, aIntBuffer);
mainbuffer = copyBuffer;
aIntBuffer = aGZIPInputStream.read(tempbuffer);
lenMainBuffer = mainbuffer.length;
}
primaryDocumentOutputDocument.setBody(mainbuffer);
wfc.putPrimaryDocument(primaryDocumentOutputDocument);
}
将数据写入ByteArrayOutputStream
。它包装一个字节数组,并在需要时调整其大小。完成后,调用toByteArray
将返回字节。
ByteArrayOutputStream和您在这里所写的内容之间的一个区别是,典型的实现是备份阵列大小的两倍,这意味着写入n个字节具有O(n)摊销的时间复杂性。如果像这里这样以固定增量增长数组,则会得到O(n^2)的时间复杂度。