【发布时间】:2020-05-19 11:51:37
【问题描述】:
我有一个使用以下方法解压缩大型 zip 文件的功能。它们是我遇到OutOfMemoryError 错误的时候,因为文件太大了。有没有办法优化我的代码?我读过一些关于将文件分解成可以放入内存并解压缩的较小部分的内容,但我不知道该怎么做。任何帮助或建议表示赞赏。
private static String decompress(String s){
String pathOfFile = null;
try(BufferedReader reader = new BufferedReader(new InputStreamReader(new GZIPInputStream(new FileInputStream(s)), Charset.defaultCharset()))){
File file = new File(s);
FileOutputStream fos = new FileOutputStream(file);
String line;
while((line = reader.readLine()) != null){
fos.write(line.getBytes());
fos.flush();
}
pathOfFile = file.getAbsolutePath();
} catch (IOException e) {
e.printStackTrace();
}
return pathOfFile;
}
堆栈跟踪:
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at java.base/java.util.Arrays.copyOf(Arrays.java:3689)
at java.base/java.util.ArrayList.grow(ArrayList.java:237)
at java.base/java.util.ArrayList.ensureCapacity(ArrayList.java:217)
【问题讨论】:
-
您对输入和输出文件都使用
s,这是行不通的。你不能写你正在阅读的同一个文件。
标签: java compression gzip binaryfiles