一、將預見可能引起異常的代碼包含在try語句塊中。 數據庫
二、若是發生了異常,則轉入catch的執行。spa
catch有幾種寫法:.net
catch 這將捕獲任何發生的異常。調試
catch(Exception e) 這將捕獲任何發生的異常。另外,還提供e參數,你能夠在處理異常時使用e參數來得到有關異常的信息。code
catch(Exception的派生類 e) 這將捕獲派生類定義的異常,例如安卓中文網,我想捕獲一個無效操做的異常,能夠以下寫:blog
catch(InvalidOperationException e) { .... } 這樣,若是try語句塊中拋出的異常是InvalidOperationException,將轉入該處執行,其餘異常不處理。 資源
catch能夠有多個,也能夠沒有,每一個catch能夠處理一個特定的異常。.net按照你catch的順序查找異常處理塊,若是找到,則進行處理,若是找不到,則向上一層次拋出。若是沒有上一層次,則向用戶拋出,此時,若是你在調試,程序將中斷運行,若是是部署的程序,將會停止。 若是沒有catch塊,異常老是向上層(若是有)拋出,或者中斷程序運行。 部署
三、finally string
finally能夠沒有,也能夠只有一個。不管有沒有發生異常,它總會在這個異常處理結構的最後運行。即便你在try塊內用return返回了,在返回前,finally老是要執行,這以便讓你有機會可以在異常處理最後作一些清理工做。如關閉數據庫鏈接等等。 it
注意:若是沒有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
}
帶程序的解讀: C#中的try-catch語句使用方法
try-catch錯誤處理表達式容許將任何可能發生異常情形的程序代碼放置在try{}程序代碼塊進行監控,真正處理錯誤異常的程序代碼則被放置在catch{}塊內,一個try{}塊可對應多個catch{}塊。
示例 try-catch語句寫入多個catch的使用 經過兩個catch語句進行捕獲異常,它們分別是ArgumentNullException異常和Exception異常。程序代碼以下:
using System; using System.Collections.Generic; using System.Text; namespace _3_16{ class Program{ static void ProcessString(string str){ if (str == null) {
throw new ArgumentNullException(); } } static void Main(){ Console.WriteLine("輸出結果爲:"); try { string str = null; ProcessString(str); //將任何可能發生異常情形的程序代碼放置在try中進行監控 } catch (ArgumentNullException e)//真正處理錯誤異常的程序代碼則被放置在catch{}塊內 { Console.WriteLine("{0} First exception.", e.Message); } catch (Exception e) { Console.WriteLine("{0} Second exception.", e.Message); } } } }