C++ 参考手册
- C++11
- C++14
- C++17
- C++20
- C++ 编译器支持情况表
- 独立与宿主实现
- C++ 语言
- C++ 关键词
- 预处理器
- C++ 标准库头文件
- 具名要求
- 功能特性测试 (C++20)
- 工具库
- 类型支持(基本类型、RTTI、类型特性)
- 概念库 (C++20)
- 错误处理
- std::exception_ptr
- std::error_code
- std::error_condition
- std::terminate
- std::exception
- std::current_exception
- std::rethrow_exception
- std::make_exception_ptr
- std::unexpected
- std::uncaught_exception, std::uncaught_exceptions
- assert
- errno
- std::nested_exception
- std::throw_with_nested
- std::rethrow_if_nested
- std::terminate_handler
- std::get_terminate
- std::set_terminate
- std::bad_exception
- std::unexpected_handler
- std::get_unexpected
- std::set_unexpected
- 错误号
- std::logic_error
- std::invalid_argument
- std::domain_error
- std::length_error
- std::out_of_range
- std::runtime_error
- std::range_error
- std::overflow_error
- std::underflow_error
- std::tx_exception
- std::error_category
- std::generic_category
- std::system_category
- std::errc
- std::system_error
- 注释
- 动态内存管理
- 日期和时间工具
- 字符串库
- 容器库
- 迭代器库
- 范围库 (C++20)
- 算法库
- 数值库
- 输入/输出库
- 文件系统库
- 本地化库
- 正则表达式库
- 原子操作库
- 线程支持库
- 实验性 C++ 特性
- 有用的资源
- 索引
- std 符号索引
- 协程支持 (C++20)
- C++ 关键词
std::throw_with_nested
定义于头文件 <exception>
|
||
template< class T > [[noreturn]] void throw_with_nested( T&& t ); |
(C++11 起) | |
若 std::decay<T>::type 是非 final 、非 union 、既非 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 | - | 要抛出的异常对象 |
返回值
(无)
示例
演示构造并通过 nested_exception 对象递归
运行此代码
#include <iostream> #include <stdexcept> #include <exception> #include <string> #include <fstream> // 打印异常的解释性字符串。若异常内嵌,则递归打印其保有的异常的解释 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& e) { print_exception(e, 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 中的异常 (函数模板) |