6

我做了一些测试(使用 Windows 7、Eclipse Juno 4.2.1 和 Java 7 SE),发现如果方法没有在 catch-block 中显式返回,并且如果在 try/catch 之外声明了对象,则没有“资源泄漏”警告信号。

不产生“资源泄漏”:

    public void extISImReturnNoWarning() {
    InputStream is = null;
    try {
        is = new FileInputStream("A");
        is.available();
    } catch (IOException e) {
    }
}

代码中的小改动会产生“资源泄漏”:

public void locISImReturnHasWarning() {
    try {
        InputStream is = new FileInputStream("A");
        is.available();
    } catch (IOException e) {
    }
}

public void extISExReturnHasWarning() {
    InputStream is = null;
    try {
        is = new FileInputStream("A");
        is.available();
    } catch (IOException e) {
        return;
    }
}

所有方法在功能上似乎都是相同的——那么解释是什么?如果这是一个错误,这是 Eclipse 还是 Java 问题?

4

1 回答 1

2

经过一番研究,我得出结论,这是一个 Eclipse 错误。我已经在 Eclipse 下载站点 (Kepler M3) 上找到的最新版本中对其进行了测试,但问题仍然存在。我还发现了 5-6 个关于过去 30 天在 Eclipse 项目中报告的类似问题的错误报告。在研究过程中,我还发现了另一种奇特的行为:

    public void makeConnection() throws SQLException {
    Connection connection = null;
    try {
        connection = DriverManager.getConnection("localhost");
        for (int i = 0; i < 1; i++)
            if (i < 1)
                throw new SQLException("Foo");
        connection.commit();
    } finally {
        close(connection);
    }
}

public void close(Connection c) {
}

此代码将生成资源泄漏警告。但是,通过删除其中之一

  • 关闭(连接)的调用
  • for循环

..资源泄漏警告将消失。奇怪的是 - 在普通情况下不会报告资源泄漏,您只需创建一个连接而不关闭它。

总而言之,我认为 Eclipse Juno 中的资源泄漏检测暂时可能有点容易出错。也许现在最好忽略 Eclipse 中的资源泄漏,等待 Kepler。

2014 年 12 月更新:当前正在运行 Eclipse Luna,问题仍然存在......

于 2012-12-04T20:29:37.563 回答