try-except 陳述式 (C)
Microsoft 特定
try-except
陳述式是 Microsoft C 語言的延伸模組,可讓應用程式在發生通常會終止程式執行的事件時取得程式控制權。 這類事件稱為例外狀況,而處理例外狀況的機制稱為結構化例外狀況處理。
例外狀況可能以硬體或軟體為主。 即使應用程式無法完全從硬體或軟體例外狀況中復原,結構化例外狀況處理也可以記錄和顯示錯誤訊息。 捕捉應用程式的內部狀態有助於診斷問題。 特別是,它對於解決不易重現的間歇性問題很有幫助。
語法
try-except-statement
:
__try
compound-statement
__except (
expression
)
compound-statement
__try
子句後面的複合陳述式是受保護的區段。 __except
子句後面的複合陳述式則是例外狀況處理常式。 此處理常式會指定在執行受保護的區段期間引發例外狀況時要採取的一組動作。 執行程序如下所示:
執行保護的區段。
如果執行保護的區段時未發生例外狀況,則會在
__except
子句之後的陳述式繼續執行。如果在執行保護的區段時或在受保護的區段所呼叫的任何常式中發生例外狀況,就會評估
__except
運算式。 傳回的值會決定如何處理例外狀況。 有三個可能的值:EXCEPTION_CONTINUE_SEARCH
:該例外狀況未被辨識。 繼續搜尋堆疊中的處理常式,首先搜尋包含try-except
陳述式,然後是具有次高優先順序的處理常式。EXCEPTION_CONTINUE_EXECUTION
:該例外狀況已被辨識但被忽略。 在例外狀況發生的位置繼續執行。EXCEPTION_EXECUTE_HANDLER
該例外狀況已被辨識。 執行__except
複合陳述式,然後在發生例外狀況的點繼續執行,將控制項傳送給例外狀況處理常式。
因為 __except
運算式會以 C 運算式求值,所以限於單一值、條件運算式運算子或逗號運算子。 如果需要更廣泛的處理,運算式可以呼叫常式,傳回上面所列三個值的其中一個。
注意
結構化例外狀況處理可搭配 C 和 C++ 原始程式檔使用。 不過,它不是專為 C++ 所設計。 針對可攜 C++ 程式,應該使用 C++ 例外狀況處理,而不是結構化例外狀況處理。 此外,C++ 例外狀況處理機制更有彈性,因為它可以處理任何類型的例外狀況。 如需詳細資訊,請參閱 C++ 語言參考中的例外狀況處理。
應用程式中的每個常式都可以有其本身的例外狀況處理常式。 __except
運算式會在 __try
主體的範圍內執行。 它可以存取在此宣告的任何區域變數。
__leave
關鍵字在 try-except
陳述式區塊內是有效的。 __leave
的作用是會跳到 try-except
區塊的結尾。 會在例外狀況處理常式結束之後繼續執行。 雖然 goto
陳述式可用來達到相同的結果,但 goto
陳述式會造成堆疊回溯的情形。 因為不包含堆疊回溯,因此使用 __leave
陳述式會更有效率。
使用 longjmp
執行階段函式結束 try-except
陳述式會視為是異常終止。 雖然跳入 __try
陳述式是不合法的,但跳出該陳述式是合法的。 如果處理序在執行 try-except
陳述式的過程中被終止,則不會呼叫例外狀況處理常式。
範例
以下是例外狀況處理常式和終止處理常式的範例。 如需終止處理常式的詳細資訊,請參閱 try-finally
陳述式 (C)。
.
.
.
puts("hello");
__try {
puts("in try");
__try {
puts("in try");
RAISE_AN_EXCEPTION();
} __finally {
puts("in finally");
}
} __except( puts("in filter"), EXCEPTION_EXECUTE_HANDLER ) {
puts("in except");
}
puts("world");
以下是範例的輸出,右邊新增了註解:
hello
in try /* fall into try */
in try /* fall into nested try */
in filter /* execute filter; returns 1 so accept */
in finally /* unwind nested finally */
in except /* transfer control to selected handler */
world /* flow out of handler */
結束 Microsoft 專屬