首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >关闭可能引发异常的资源

关闭可能引发异常的资源
EN

Stack Overflow用户
提问于 2014-12-01 20:38:23
回答 3查看 90关注 0票数 3
  • 从池中获取一个Connection (这可能引发异常)
  • 在连接之外创建一个Statement (也可能引发异常)
  • 使用该语句执行SQL查询,并将其存储在ResultSet中(也可以抛出)
  • 处理查询结果
  • 关闭ResultSet (异常!)
  • 关闭Statement (异常!)
  • 关闭Connection (异常!)

看看这段代码:

代码语言:javascript
复制
    Connection  conn = null;
    Statement   st   = null;
    ResultSet   set  = null;
    try {
        conn    = Database.getConnection();
        st      = conn.createStatement();
        set     = st.executeQuery("SELECT * FROM THING");

        // <-- Do stuff
    } catch (Exception e) {

    } finally {
        // Close set if possible
        if (set != null) {
            try {
                set.close();
            } catch (Exception e) {

            }
        }

        // Close statement if possible
        if (st != null) {
            try {
                st.close();
            } catch (Exception e) {

            }
        }

        // Close connection if possible
        if (conn != null) {
            try {
                conn.close();
            } catch (Exception e) {

            }
        }
    }

finally街区是我关闭物品的地方。正如你所看到的,这是非常混乱的。我的问题是:这是清理这些资源的正确方法吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-12-01 20:44:23

在Java1.7之前,您的代码是捕获可关闭资源的异常的正确方法,只是您应该捕获SQLException而不是Exception

从Java1.7开始,您可以使用the "try-with-resources" statement,它允许您声明资源,这些资源将在close()块完成时自动调用,从而保存样板finally代码。

代码语言:javascript
复制
try (Connection conn = Database.getConnection(); Statement st = conn.createStatement();
     ResultSet set = st.executeQuery("SELECT * FROM THING")) {
   // Your "try" code as before
}
catch (SQLException e) {
   // Handle as before
}
// No "finally" to clean up resources needed!
票数 5
EN

Stack Overflow用户

发布于 2014-12-01 20:44:02

如果可以(至少需要Java 7) http://docs.oracle.com/javase/tutorial/essential/exceptions/tryResourceClose.html,请使用参考资料查看一下

票数 1
EN

Stack Overflow用户

发布于 2014-12-01 20:50:42

是的,但是您可以通过编写可重用的代码(最好是在实用程序类中)来使它看起来更好看。

代码语言:javascript
复制
public static void close(Statement st) {
    if (st != null) {
        try {
            st.close();
        } catch (SQLException e) {
            // log exception
        }
    }
}

并在最终块中使用此方法。为ConnectionResultSet添加类似的方法

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27236853

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档