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