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

如果执行了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日

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效