std:: nested_exception
      From cppreference.net
     
     
     | 
           定义于头文件
            
            
             <exception>
            
            | ||
| 
           
            
             class
            
            nested_exception
            
             ;
            
           
           | (C++11 起) | |
       
        std::nested_exception
       
       是一个多态混入类,能够捕获并存储当前异常,使得任意类型的异常可以相互嵌套。
      
| 
           | (since C++26) | 
| 目录 | 
成员函数
| 构造 nested_exception (公开成员函数) | |
| 
           
            
             
              [virtual]
             
            
           
           | 析构嵌套异常 (虚公开成员函数) | 
| 替换 nested_exception 的内容 (公开成员函数) | |
| 抛出存储的异常 (公开成员函数) | |
| 获取指向存储异常的指针 (公开成员函数) | 
非成员函数
| 
           
            
             
              (C++11)
             
            
           
           | 抛出混入
         
          
           std::nested_exception
          
         
         的实参 (函数模板) | 
| 
           
            
             
              (C++11)
             
            
           
           | 从
         
          
           std::nested_exception
          
         
         抛出异常 (函数模板) | 
注释
| 功能测试 宏 | 值 | 标准 | 功能 | 
|---|---|---|---|
| 
           __cpp_lib_constexpr_exceptions
           | 
           202411L
           | (C++26) | constexpr for exception types | 
示例
演示通过嵌套异常对象实现的构造与递归。
         运行此代码
        
       #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 (...) {} } // 捕获异常并将其包装为嵌套异常的示例函数 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)); } } // 捕获异常并将其包装为嵌套异常的示例函数 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
          
         
         的参数 (函数模板) | 
| 
           
            
             
              (C++11)
             
            
           
           | 从
         
          
           std::nested_exception
          
         
         中抛出异常 (函数模板) |