try
catch
finally
一、將預見可能引起異常的代碼包含在try語句塊中。
二、若是發生了異常,則轉入catch的執行。catch有幾種寫法:
catch
這將捕獲任何發生的異常。
catch(Exception e)
這將捕獲任何發生的異常。另外,還提供e參數,你能夠在處理異常時使用e參數來得到有關異常的信息。
catch(Exception的派生類 e)
這將捕獲派生類定義的異常,例如,我想捕獲一個無效操做的異常,能夠以下寫:
catch(InvalidOperationException e)
{
....
}
這樣,若是try語句塊中拋出的異常是InvalidOperationException,將轉入該處執行,其餘異常不處理。
catch能夠有多個,也能夠沒有,每一個catch能夠處理一個特定的異常。.net按照你catch的順序查找異常處理塊,若是找到,則進行處理,若是找不到,則向上一層次拋出。若是沒有上一層次,則向用戶拋出,此時,若是你在調試,程序將中斷運行,若是是部署的程序,將會停止。
若是沒有catch塊,異常老是向上層(若是有)拋出,或者中斷程序運行。
三、finally
finally能夠沒有,也能夠只有一個。不管有沒有發生異常,它總會在這個異常處理結構的最後運行。即便你在try塊內用return返回了,在返回前,finally老是要執行,這以便讓你有機會可以在異常處理最後作一些清理工做。如關閉數據庫鏈接等等。
注意:若是沒有catch語句塊,那麼finally塊就是必須的。html
若是你不但願在這裏處理異常,而當異常發生時提交到上層處理,但在這個地方不管發生異常,都要必需要執行一些操做,就可使用try finally,
很典型的應用就是進行數據庫操做:
用下面這個原語來講明:
try
{
DataConnection.Open();
DataCommand.ExecuteReader();
...
return;
}
finally
{
DataConnection.Close();
}
不管是否拋出異常,也不管從什麼地方return返回,finally語句塊老是會執行,這樣你有機會調用Close來關閉數據庫鏈接(即便未打開或打開失敗,關閉操做永遠是能夠執行的),以便於釋放已經產生的鏈接,釋放資源。
順便說明,return是能夠放在try語句塊中的。但無論在什麼時機返回,在返回前,finally將會執行。數據庫
小結.net
try { //執行的代碼,其中可能有異常。一旦發現異常,則當即跳到catch執行。不然不會執行catch裏面的內容 }3d
catch { //除非try裏面執行代碼發生了異常,不然這裏的代碼不會執行 }調試
finally { //無論什麼狀況都會執行,包括try catch 裏面用了return ,能夠理解爲只要執行了try或者catch,就必定會執行 finally }htm
origin:http://blog.sina.com.cn/s/blog_63dac1ed01013iuh.htmlblog