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。
unexpected_handler
此類型描述的函式指標適合作為 unexpected_handler。
typedef void (*unexpected_handler)();