深入淺析java中finally的用法
finally作為異常處理的一部分,它只能用在try/catch語句中,并且附帶一個(gè)語句塊,表示這段語句最終一定會(huì)被執(zhí)行(不管有沒有拋出異常),經(jīng)常被用在需要釋放資源的情況下。
之前在寫爬蟲的時(shí)候數(shù)據(jù)庫連接的頻率很高,有時(shí)候數(shù)據(jù)處理的不好,sql報(bào)錯(cuò)后,拋出異常但后邊的數(shù)據(jù)庫連接沒有斷開。導(dǎo)致最后數(shù)據(jù)庫連接數(shù)過大,不讓再連接了(因?yàn)槭莻€(gè)人庫,所以直接重啟了一下)。這個(gè)釋放數(shù)據(jù)庫連接的操作就可以用finally來進(jìn)行。
首先看一下沒有用finally的代碼(不能直接運(yùn)行,能看懂什么意思就行)
Connection conn;
Statement stmt;
try{
conn = DriverManager.getConnection(url,userName,password);
stmt = conn.createStatement;
String sql = "sql";//需要執(zhí)行的sql
stmt.executeUpdate(sql);
stmt.close();
conn.close();
}catch(Exception e){
e.printStackTrace();
}
在程序正常運(yùn)行的時(shí)候,沒有異常拋出,沒有問題。
但在程序拋出異常(sql出錯(cuò)了),try里面的語句不執(zhí)行了直接被執(zhí)行catch里面的語句了,就造成了一個(gè)數(shù)據(jù)庫連接沒有正常關(guān)閉。數(shù)據(jù)量如果大起來,數(shù)據(jù)庫的最大連接數(shù)到達(dá)上限,就不再允許創(chuàng)建新的連接了。
然后finally的用處現(xiàn)在就能體現(xiàn)出來了
Connection conn = null;
Statement stmt = null;
try {
conn = DriverManager.getConnection(url,userName,password);
stmt = conn.createStatement;
String sql = "sql";//需要執(zhí)行的sql
stmt.executeUpdate(sql);
stmt.close();
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}finally{
if(stmt! = NULL){
stmt.close();
}
if(conn! = NULL){
conn.close();
}
}
這樣即使sql運(yùn)行出錯(cuò),拋出了異常,在最后的finally代碼中再進(jìn)行一次數(shù)據(jù)庫連接的判斷,就可以保證數(shù)據(jù)庫連接資源不會(huì)被平白無故的浪費(fèi)掉。
以上所述是小編給大家介紹的java中finally的用法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
VSCode中開發(fā)JavaWeb項(xiàng)目的詳細(xì)過程(Maven+Tomcat+熱部署)
這篇文章主要介紹了VSCode中開發(fā)JavaWeb項(xiàng)目(Maven+Tomcat+熱部署),本文分步驟通過圖文并茂的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
仿釘釘流程輕松實(shí)現(xiàn)JSON轉(zhuǎn)BPMN完整實(shí)現(xiàn)過程示例
這篇文章主要為大家介紹了仿釘釘流程輕松實(shí)現(xiàn)JSON轉(zhuǎn)BPMN完整實(shí)現(xiàn)過程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08

