<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??一站式輕松地調用各大LLM模型接口,支持GPT4、智譜、豆包、星火、月之暗面及文生圖、文生視頻 廣告
                #### 28. 異常處理 異常是程序在執行期間產生的問題。C++ 異常是指在程序運行時發生的特殊情況,比如嘗試除以零的操作。 異常提供了一種轉移程序控制權的方式。C++ 異常處理涉及到三個關鍵字:**try、catch、throw**。 * **throw:** 當問題出現時,程序會拋出一個異常。這是通過使用 **throw** 關鍵字來完成的。 * **catch:** 在您想要處理問題的地方,通過異常處理程序捕獲異常。**catch** 關鍵字用于捕獲異常。 * **try:** **try** 塊中的代碼標識將被激活的特定異常。它后面通常跟著一個或多個 catch 塊。 如果有一個塊拋出一個異常,捕獲異常的方法會使用 **try** 和 **catch** 關鍵字。try 塊中放置可能拋出異常的代碼,try 塊中的代碼被稱為保護代碼。使用 try/catch 語句的語法如下所示: ~~~ try { // 保護代碼 }catch( ExceptionName e1 ) { // catch 塊 }catch( ExceptionName e2 ) { // catch 塊 }catch( ExceptionName eN ) { // catch 塊 } 復制代碼 ~~~ 如果 **try** 塊在不同的情境下會拋出不同的異常,這個時候可以嘗試羅列多個 **catch** 語句,用于捕獲不同類型的異常。 **拋出異常:** 您可以使用 **throw** 語句在代碼塊中的任何地方拋出異常。throw 語句的操作數可以是任意的表達式,表達式的結果的類型決定了拋出的異常的類型。 以下是嘗試除以零時拋出異常的實例: ~~~ double division(int a, int b) { if( b == 0 ) { throw "Division by zero condition!"; } return (a/b); } 復制代碼 ~~~ **捕獲異常:** **catch** 塊跟在 **try** 塊后面,用于捕獲異常。您可以指定想要捕捉的異常類型,這是由 catch 關鍵字后的括號內的異常聲明決定的。 ~~~ try { // 保護代碼 }catch( ExceptionName e ) { // 處理 ExceptionName 異常的代碼 } 復制代碼 ~~~ 下面是一個實例,拋出一個除以零的異常,并在 catch 塊中捕獲該異常。 ~~~ #include <iostream> using namespace std; double division(int a, int b) { if( b == 0 ) { throw "Division by zero condition!"; } return (a/b); } int main () { int x = 50; int y = 0; double z = 0; try { z = division(x, y); cout << z << endl; }catch (const char* msg) { cerr << msg << endl; } return 0; } 復制代碼 ~~~ 由于我們拋出了一個類型為 **const char\*** 的異常,因此,當捕獲該異常時,我們必須在 catch 塊中使用 const char\*。當上面的代碼被編譯和執行時,它會產生下列結果: > **輸出:** > > Division by zero condition! **自定義異常:** 您可以通過繼承和重載 **exception** 類來定義新的異常。下面的實例演示了如何使用 std::exception 類來實現自己的異常: ~~~ //自定義一個新的異常 class MyException : public std::exception{ public: const char* what() const throw(){ return "C++ 操作失誤,請檢查代碼是否正確!"; } }; //測試: void test25() { try { throw "空指針異常"; } catch (const char *msg) { cout << "錯誤日志:\t" << msg << endl; } //自定義異常 try { throw MyException(); } catch (MyException exception) { cout << "自定義異常:" << exception.what() << endl; } catch (exception &error) { cout << "其它異常:" << error.what() << endl; } } 復制代碼 ~~~ > **輸出:** > > 錯誤日志: 空指針異常 自定義異常:C++ 操作失誤,請檢查代碼是否正確!
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看