首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2SE开发 >

对于怎样关闭Connection,ResultSet,PreparedStatement

2011-12-21 
关于怎样关闭Connection,ResultSet,PreparedStatementJava code方法1:try {if (rs ! null) {rs.close()}

关于怎样关闭Connection,ResultSet,PreparedStatement

Java code
方法1:try {                    if (rs != null) {                        rs.close();                    }                    if (p != null) {                        p.close();                    }                    if (connection != null) {                        connection.close();                    }                } catch (SQLException e) {                    e.printStackTrace();                }方法2:try {        if (rs != null) {            rs.close();        }} catch (SQLException e) {        e.printStackTrace();    }Try{        if (p != null) {            p.close();        }} catch (SQLException e) {        e.printStackTrace();    }Try{        if (connection != null) {            connection.close();        }} catch (SQLException e) {        e.printStackTrace();    }


哪一个更好

[解决办法]
后面一个更好,try - catch分得更细一些.
[解决办法]
第一个更好,使用 try 块会产生大量的时间消耗,对于会产生异常的程序应尽量放置在一个 try 块里。
[解决办法]
对性能上有什么作用?
在关闭rs,p的时候会不会出现异常?
[解决办法]
后一个更好
关闭一般不会出异常
节省性能
[解决办法]
bao110908 
如果在关闭rs,p的时候出现异常怎么办?
[解决办法]
try {
} catch() {
} finally {
if (rs != null) {
rs.close();
rs = null;
}
if (p != null) {
p.close();
p = null;
}
if (connection != null) {
connection.close();
connection = null;
}
}
个人认为这样会更好一点
[解决办法]
对性能上有什么作用? 
在关闭rs,p的时候会不会出现异常?
______________

只要把方法 1 的代码,整个搬到 finally 块中就可以了。

热点排行