如何進(jìn)行C#異常類的自定義
首先我們建立自己的C#異常類 CustomException,它要繼承自ApplicationException類(這是一個在發(fā)生非致命的應(yīng)用程序錯誤時拋出的通用異常,它又繼承于更為通用的Exception類),將其用作為應(yīng)用程序定義的任何自定義異常的基類。通過這個基類,我們就可以編寫一個通用的catch代碼塊,捕獲應(yīng)用程序定義的任何自定義異常類型。
自定義的異常類型可以在這中間扮演一個非常重要的角色。我們可以捕獲一個通用的異常,識別它和應(yīng)用程序的關(guān)系,然后把它作為特定于應(yīng)用程序的異常再次拋出,以便能適當(dāng)?shù)靥幚硭?/P>
這里構(gòu)建了一個簡單的場景,使用Northwind數(shù)據(jù)庫,向其中添加一條Customer記錄,如果ID重復(fù)則拋出相應(yīng)的異常信息。
(1) 定義我們的基礎(chǔ)異常類
- public class CustomException:ApplicationException
- {
- public CustomException()
- {
- }
- public CustomException(string message, Exception inner):base(message,inner)
- {
- }
- }
定義兩個處理異常的方法,使用base關(guān)鍵字讓CustomException方法繼承自基本的錯誤異常類ApplicationException并提供了兩個參數(shù),一個異常消息參數(shù)和一個異常錯誤類。
(2) 然后我們再定一個處理我們不同自定義錯誤類型的錯誤處理類,不同的應(yīng)用程序異常類型使用不同的異常處理類。
- public class DuplicateCustomerIDException : CustomException
- {
- public DuplicateCustomerIDException()
- {
- }
- public DuplicateCustomerIDException(string message, Exception inner):base(message,inner)
- {
- }
- }
當(dāng)出現(xiàn)相應(yīng)類型的異常時,在這個自定義異常處理中可以在出現(xiàn)錯誤的時候做一系列的處理,然后再拋出異常信息,例如:記錄錯誤日志,或者做容錯處理等。
(3) ***我們在添加客戶記錄的時候,使用我們自定義的C#異常類
- private void AddCustomerRecord()
- {
- SqlConnection cn = new SqlConnection(DBConn);
- cn.Open();
- try
- {
- SqlCommand com = new SqlCommand("Insert Into Customers (CustomerID,CompanyName,ContactName) Values ('"+ftxt_CustomerID.Text+"','"+ftxt_CompanyName.Text+"','"+ftxt_ContactName.Text+"')",cn);
- com.ExecuteNonQuery();
- }
- catch(SqlException ex)
- {
- if(ex.Number == 2627)
- {
- throw new DuplicateCustomerIDException("CustomerID重復(fù)",ex);
- }
- else
- {
- MessageBox.Show("成功","提示信息",MessageBoxButtons.OK,MessageBoxIcon.Information,MessageBoxDefaultButton.Button1,MessageBoxOptions.DefaultDesktopOnly);
- }
- }
- finally
- {
- cn.Close();
- }
- }
其中的ex.Number == 2627就是由于數(shù)據(jù)表中主鍵重復(fù)不能添加重復(fù)主鍵的記錄時拋出的異常號碼,如果異常類型符合怎拋出我們自定義的異常處理類。
(4) ***我們在調(diào)用這個方法時,編寫代碼捕獲這個我們自定義類型的異常
- private void fbtn_Submit_Click(object sender, System.EventArgs e)
- {
- try
以上就實現(xiàn)了C#異常類的自定義。
【編輯推薦】


2011-12-16 14:23:51
2009-08-04 08:58:01
2010-12-24 15:38:53
2009-08-04 12:56:51
2009-08-17 17:24:02
2009-08-05 17:03:37




