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::rethrow_if_nested
定义于头文件 <exception>
|
||
template< class E > void rethrow_if_nested( const E& e ); |
(C++11 起) | |
若 E
不是多态类类型,或若 std::nested_exception 是 E
的不可访问或有歧义基类,则无效果。
否则,进行
if (auto p = dynamic_cast<const std::nested_exception*>(std::addressof(e))) p->rethrow_nested();
参数
e | - | 要重抛的异常对象 |
返回值
(无)
可能的实现
namespace details { template <class E> struct can_dynamic_cast : std::integral_constant<bool, std::is_polymorphic<E>::value && (!std::is_base_of<std::nested_exception, E>::value || std::is_convertible<E*, std::nested_exception*>::value) > { }; template <class T> void rethrow_if_nested_impl(const T& e, std::true_type) { if(auto nep = dynamic_cast<const std::nested_exception*>(std::addressof(e))) nep->rethrow_nested(); } template <class T> void rethrow_if_nested_impl(const T&, std::false_type) { } } template <class T> void rethrow_if_nested(const T& t){ details::rethrow_if_nested_impl(t, details::can_dynamic_cast<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 (函数模板) |