如何進行C#異常類的自定義
首先我們建立自己的C#異常類 CustomException,它要繼承自ApplicationException類(這是一個在發生非致命的應用程序錯誤時拋出的通用異常,它又繼承于更為通用的Exception類),將其用作為應用程序定義的任何自定義異常的基類。通過這個基類,我們就可以編寫一個通用的catch代碼塊,捕獲應用程序定義的任何自定義異常類型。
自定義的異常類型可以在這中間扮演一個非常重要的角色。我們可以捕獲一個通用的異常,識別它和應用程序的關系,然后把它作為特定于應用程序的異常再次拋出,以便能適當地處理它。
這里構建了一個簡單的場景,使用Northwind數據庫,向其中添加一條Customer記錄,如果ID重復則拋出相應的異常信息。
(1) 定義我們的基礎異常類
- public class CustomException:ApplicationException
- {
- public CustomException()
- {
- }
- public CustomException(string message, Exception inner):base(message,inner)
- {
- }
- }
定義兩個處理異常的方法,使用base關鍵字讓CustomException方法繼承自基本的錯誤異常類ApplicationException并提供了兩個參數,一個異常消息參數和一個異常錯誤類。
(2) 然后我們再定一個處理我們不同自定義錯誤類型的錯誤處理類,不同的應用程序異常類型使用不同的異常處理類。
- public class DuplicateCustomerIDException : CustomException
- {
- public DuplicateCustomerIDException()
- {
- }
- public DuplicateCustomerIDException(string message, Exception inner):base(message,inner)
- {
- }
- }
當出現相應類型的異常時,在這個自定義異常處理中可以在出現錯誤的時候做一系列的處理,然后再拋出異常信息,例如:記錄錯誤日志,或者做容錯處理等。
(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重復",ex);
- }
- else
- {
- MessageBox.Show("成功","提示信息",MessageBoxButtons.OK,MessageBoxIcon.Information,MessageBoxDefaultButton.Button1,MessageBoxOptions.DefaultDesktopOnly);
- }
- }
- finally
- {
- cn.Close();
- }
- }
其中的ex.Number == 2627就是由于數據表中主鍵重復不能添加重復主鍵的記錄時拋出的異常號碼,如果異常類型符合怎拋出我們自定義的異常處理類。
(4) ***我們在調用這個方法時,編寫代碼捕獲這個我們自定義類型的異常
- private void fbtn_Submit_Click(object sender, System.EventArgs e)
- {
- try
以上就實現了C#異常類的自定義。
【編輯推薦】