<exception>
typedef
exception_ptr
描述例外狀況指標的類型。
typedef unspecified exception_ptr;
備註
用於實作 exception_ptr
類型的未指定內部類別。
利用 exception_ptr
物件參考目前的例外狀況或使用者指定的例外狀況執行個體。 在 Microsoft 實作中,例外狀況是以 EXCEPTION_RECORD 結構表示。 每個 exception_ptr
物件均包含一個例外狀況參考欄位,指向代表該例外狀況的 EXCEPTION_RECORD
結構複本。
當您宣告 exception_ptr
變數時,此變數尚未關聯任何例外狀況。 也就是說,其例外狀況參考欄位為 NULL。 這樣的 exception_ptr
物件稱為 null exception_ptr。
利用 current_exception
或 make_exception_ptr
函式將例外狀況指派給 exception_ptr
物件。 當您將例外狀況指派給 exception_ptr
變數時,此變數的例外狀況參考欄位會指向該例外狀況的複本。 如果記憶體空間不足,無法複製該例外狀況,則例外狀況參考欄位會指向 std::bad_alloc 例外狀況的複本。 current_exception
如果 或 make_exception_ptr
函式因任何其他原因而無法複製例外狀況,函式會呼叫 terminate
CRT函式以結束目前的進程。
exception_ptr
物件本身並不是指標 (儘管其名稱如此)。 此物件不會遵守指標語意,也不能搭配指標成員存取 (->
) 或間接取值 (*) 運算子使用。 exception_ptr
物件沒有公用資料成員或成員函式。
比較:
您可以使用等於 (==
) 和不等於 (!=
) 運算子比較兩個 exception_ptr
物件。 運算子不會比較代表例外狀況之 EXCEPTION_RECORD
結構的二進位值 (位元模式)。 相反地,運算子會比較 exception_ptr
物件的例外狀況參考欄位位址。 因此,Null exception_ptr
和 Null 值的比較結果是相等。
terminate_handler
此類型描述適合做為 terminate_handler
之函式的指標。
typedef void (*terminate_handler)();
備註
此類型描述適合做為終止處理常式之函式的指標。
範例
如需 terminate_handler
的用法範例,請參閱 set_terminate。
unexpected_handler
此類型描述的函式指標適合作為 unexpected_handler
。
typedef void (*unexpected_handler)();
範例
如需 unexpected_handler
的用法範例,請參閱 set_unexpected。