最近在写JDBC的工具类
写到getConnection方法和close方法时,产生了疑惑。
/**
* 获取连接
* @return 连接对象
*/
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(url, user, password);
}
/**
* 释放资源
* @param stmt
* @param conn
*/
public static void close(Statement stmt,Connection conn){
if( stmt != null){
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if( conn != null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
疑惑是为什么getConnection方法时处理
DriverManager.getConnection(url, user, password);
的异常时抛出了SQLException,为什么不try-catch
为什么close释放资源的时候采用的是try-catch而不是抛出
关键点分析:
1、throw 异常之后,后面的代码将不会执行
2、try-catch时,即使catch到了异常之后,后面的代码还是会继续执行
getConnection时没有必要采用trycatch 因为如果连数据库都连接不上,就不用谈后面对数据库的操作了。
释放资源的时候trycatch是必要的,因为不止关了一个资源。
如本例中,如果在处理statement的异常时,抛出了,后面的conn资源就关闭不了了,所以采用try-catch是恰当的。
以上均为个人分析,如有错误,还请指出,共同进步。