try catch和finally

在C#中這三個關鍵字用於處理異常。數據庫

這三個關鍵字try是一定要用的,要否則就失去了意義。而後catch和finally能夠不用可是要注意遵循原則。數組

存在一個或多個catch的時能夠不用finally,也能夠用。安全

不存在catch時,必需要用finally函數

  • try預見可能發生異常的代碼
  • catch若是發生異常,則轉入catch的執行

catch的幾種寫法:spa

     catch.net

     這將捕獲任何發生的異常3d

     catch(exception ex)指針

     這將捕獲任何發生的異常.另外,還提供ex參數,你能夠在處理異常時使用ex參數來得到有關異常信息     調試

     catch(exception 的派生類 ex)code

     這將捕獲派生類定義的異常,例如,我想捕獲一個無效操做的異常InvalidOperationException,這樣,若是try語句中拋出的異常是InvalidOperationException將轉入該處執行,其餘異常不處理

     catch能夠有多個,也能夠沒有,每一個catch處理一個特定的異常。.net按照你catch的順序查找異常處理塊,若是找到,則進行處理,若是找不到,則向上一層拋出。若是你在調試程序將中斷執行,若是是部署的程序,將會終止。

     如過沒有catch塊,異常老是向上層(若是有)拋出,或者中斷程序執行。    

  • finally 能夠沒有,也能夠只有一個。不管有沒有發生異常。它總會在這個異常處理結構的最後運行。即便你在try塊內使用return返回了,在返回以前,finally老是要執行,這以便讓你有機會能在異常處理最後作一些清理工做。如關閉數據庫鏈接等等。
  • 注意:若是沒有catch塊,那麼finally塊是必須的。
  • 若是你不但願在這裏處理異常。而當異常發生時提交到上層處理,但在這個地方不管是否發生異常,都必須執行一些操做,就可使用try finally。順便說明一下,return是能夠放在try語句塊中的。但無論在何時返回,在返回前finally將會執行

   try  

      {  

          //執行的代碼,其中可能有異常。一旦發現異常,則當即跳到catch執行。不然不會執行catch裏面的內容 

     }  

   catch //(Exception e)  括號裏面的參數是表示的這個catch語句裏面要對應處理的錯誤類型及其參數

   {          

        //throw new Exception("轉化失敗");  

        //除非try裏面執行代碼發生了異常,不然這裏的代碼不會執行

    }  

   finally  

  {        

       //無論什麼狀況都會執行,包括try catch裏面用了return ,能夠理解爲只要執行了try或者catch,就必定會執行 finally

   }  

try-catch語句的兩種書寫形式

第一種:try{ 可能出錯的程序 }  catch{ 出錯後的處理方法}

   

     有運行結果能夠看出 當輸入的數字爲整數好比「3」時程序沒有出錯因此執行Console.WriteLine("你輸入的是" + i);這句話 輸出了「你輸入的是3」。 但當輸入的是小數或是字母好比「3.2」「h」時 出現了錯誤 那麼程序就跳轉到catch中執行Console.WriteLine("你輸入的字符格式有誤"); 輸出 「你輸入的字符有誤」。

 第二種:try{ 可能出現錯誤的程序 }  catch(可能出錯的地方){出錯的處理方法}

      由上面的結果能夠看出:當輸入整數「3」時 程序正常執行,但當輸入「3.2」「h」時程序不能把他們轉化成整數 那麼(Exception e)就捕獲錯誤信息並在catch「{}」中進行錯誤的處理。

 

關於throw的用法能夠用這麼個例子來簡單解釋一下:

     A類裏面有一個a方法,B類裏面有一個b方法,那麼咱們如今在a方法中調用B類的b方法,可是因爲某些緣由,b方法有時候會出現一些錯誤,可是咱們不想在b裏面處理這個錯誤,那麼咱們再b裏面能夠寫一個判斷語句

     if(錯誤的標識出現了)

     {

         throw new IndexOutOfRangeException();//這裏的錯誤類型有不少在後面列出來了,

     }

     而後再程序a中咱們能夠寫一個catch語句來截獲這個錯誤,並做出相應的處理

     Catch(IndexOutOfRangeExceptione)

    {

         MessageBox.Show(「發現IndexOutOfRangeException的錯誤」);//也能夠有其餘的處理方式,處理這種提醒式的處理,也能夠繼續拋出錯誤,讓上一層來處理

     }

錯誤的種類:

算術異常類:ArithmeticExecption
空指針異常類:NullPointerException
類型強制轉換異常:ClassCastException
數組負下標異常:NegativeArrayException
數組下標越界異常:ArrayIndexOutOfBoundsException
違背安全原則異常:SecturityException
文件已結束異常:EOFException
文件未找到異常:FileNotFoundException
字符串轉換爲數字異常:NumberFormatException
操做數據庫異常:SQLException
輸入輸出異常:IOException
方法未找到異常:NoSuchMethodException

關於throw和throws

throw 是語句拋出一個異常;throws是方法拋出一個異常;

throw語法:throw <異常對象>

throws語法:[<修飾符>]<返回值類型><方法名>([<參數列表>])[throws<異常類>]
其中:異常類能夠聲明多個,用逗號分割。

 

  • 只要try開始執行了,finally必定會執行.
  • 捕捉到的異常能夠從新拋出 ,  re-throwable
  • Try後不必定要有catch塊,可是一旦用了try關鍵字,後邊必須有catch或者finally塊,或者兩者都有

有return的狀況下try catch finally的執行順序

1.無論有沒有出現異常,finally塊中代碼都會執行

2.當try和從catch中有return時,finally仍會執行

3.finally是在return後面的表達式運算後執行的(此時並無返回運算後的值,而是先把要返回的值保存起來,無論finally中的代碼怎麼樣,返回的值都不會改變,任然是以前保存的值),因此函數返回值是在finally執行前肯定的;

4.finally中最好不要包含return,不然程序會提早退出,返回值不是try或catch中保存的返回值。

舉例:
狀況1:try{} catch(){}finally{} return;
            顯然程序按順序執行。
狀況2:try{ return; }catch(){} finally{} return;
          程序執行try塊中return以前(包括return語句中的表達式運算)代碼;
         再執行finally塊,最後執行try中return;
         finally塊以後的語句return,由於程序在try中已經return因此再也不執行。
狀況3:try{ } catch(){return;} finally{} return;
         程序先執行try,若是遇到異常執行catch塊,
         有異常:則執行catch中return以前(包括return語句中的表達式運算)代碼,再執行finally語句中所有代碼,
                     最後執行catch塊中return. finally以後也就是4處的代碼再也不執行。
         無異常:執行完try再finally再return.
狀況4:try{ return; }catch(){} finally{return;}
          程序執行try塊中return以前(包括return語句中的表達式運算)代碼;
          再執行finally塊,由於finally塊中有return因此提早退出。
狀況5:try{} catch(){return;}finally{return;}
          程序執行catch塊中return以前(包括return語句中的表達式運算)代碼;
          再執行finally塊,由於finally塊中有return因此提早退出。
狀況6:try{ return;}catch(){return;} finally{return;}
          程序執行try塊中return以前(包括return語句中的表達式運算)代碼;
          有異常:執行catch塊中return以前(包括return語句中的表達式運算)代碼;
                       則再執行finally塊,由於finally塊中有return因此提早退出。
          無異常:則再執行finally塊,由於finally塊中有return因此提早退出。
  結論1:任何執行try 或者catch中的return語句以前,都會先執行finally語句,若是finally存在的話。
                  若是finally中有return語句,那麼程序就return了,因此finally中的return是必定會被return的,
                  編譯器把finally中的return實現爲一個warning。

結果2:
	在try語句中,在執行return語句時,要返回的結果已經準備好了,就在此時,程序轉到finally執行了。
在轉去以前,try中先把要返回的結果存放到不一樣於x的局部變量中去,執行完finally以後,在從中取出返回結果,
所以,即便finally中對變量x進行了改變,可是不會影響返回結果。
它應該使用棧保存返回值。

 實例:

 

                        try
                        {
                            throw new Exception("不存在合法數據,請從新導入!");
                        }
                        catch (Exception ex)
                        {
                            throw;
                        }

 

 

 

    更多的關於try----catch的用法請轉:http://msdn.microsoft.com/zh-cn/library/0yd65esw 

相關文章
相關標籤/搜索