还是不够优雅 2020-01-17 15:42 采纳率: 50%
浏览 1540
已采纳

如果执行了zipFile.close(),zipFile.getInputStream(entry) 这个流还需要关闭吗

最近的一个项目中,使用Converity检测代码时,检测到了到了一些资源泄露问题。大概就是下面这个样子代码,检测中提到inputStream未关闭。但是我看到好多代码都是未关闭inputStream(zipFile.getInputStream(xmlEntry))这个流,所以有些疑惑,到底应不应该手动关闭这个流。

1、代码

ZipFile zipFile = null;
InputStream inputStream = null;
try{
    zipFile = new ZipFile(path);
    ZipArchiveEntry xmlEntry = zipFile.getEntry("des.xml");
    inputStream = zipFile.getInputStream(xmlEntry);
    .......
}catch(Exception e){

}finally{
    zipFile.close();
}
......
2、我的疑惑
    我在finally代码块中执行了zipFile.close(),inputStream这个流还需要手动关闭吗?

  • 写回答

3条回答 默认 最新

  • gin_91 2020-01-18 21:56
    关注

    如果不确定最好是关闭吧 , 如果ZipFile里面已经处理过相关流的关闭,那就不用了。

    另外 你可以在zipfile 被close后,debug或者打印 下 inputstream的是否已经关闭,养成自己探索和判断的好习惯哦!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已采纳回答 4月27日