std::throw_with_nested
從 cppreference.com
在標頭 <exception> 定義
|
||
template< class T > [[noreturn]] void throw_with_nested( T&& t ); |
(C++11 起) (C++26 起為 constexpr) |
|
若 std::decay<T>::type 是非 final、非聯合體類型,且既非 std::nested_exception 亦非從 std::nested_exception 派生的類類型,則拋出一個從 std::nested_exception 和 std::decay<T>::type 兩者公開派生的未指定類型的異常,它從 std::forward<T>(t) 構造。 nested_exception
基類的默認構造函數調用 std::current_exception,以一個 std::exception_ptr 捕獲當前處理的異常對象,若它存在。
否則拋出 std::forward<T>(t)。
要求 std::decay<T>::type 為可複製構造 (CopyConstructible) 。
目錄 |
[編輯] 參數
t | - | 要拋出的異常對象 |
[編輯] 註解
功能特性測試宏 | 值 | 標準 | 功能特性 |
---|---|---|---|
__cpp_lib_constexpr_exceptions |
202411L |
(C++26) | constexpr 的異常類型 |
[編輯] 示例
演示構造並通過 nested_exception 對象遞歸。
運行此代碼
#include <exception> #include <fstream> #include <iostream> #include <stdexcept> #include <string> // 打印异常的解释性字符串。若异常内嵌,则递归打印其保有的异常的解释性字符串 void print_exception(const std::exception& e, int level = 0) { std::cerr << std::string(level, ' ') << "exception: " << e.what() << '\n'; try { std::rethrow_if_nested(e); } catch (const std::exception& nestedException) { print_exception(nestedException, level + 1); } catch (...) {} } // 示例函数,捕捉异常并将其包装于 nested_exception void open_file(const std::string& s) { try { std::ifstream file(s); file.exceptions(std::ios_base::failbit); } catch (...) { std::throw_with_nested(std::runtime_error("Couldn't open " + s)); } } // 示例函数,捕捉异常并将其包装于 nested_exception void run() { try { open_file("nonexistent.file"); } catch (...) { std::throw_with_nested(std::runtime_error("run() failed")); } } // 运行上述实例函数并打印捕捉的异常 int main() { try { run(); } catch (const std::exception& e) { print_exception(e); } }
可能的輸出:
exception: run() failed exception: Couldn't open nonexistent.file exception: basic_ios::clear
[編輯] 參閱
(C++11) |
捕獲並存儲當前異常的混入類型 (類) |
(C++11) |
拋出 std::nested_exception 中的異常 (函數模板) |