标准库标头 <exception>
来自cppreference.com
此头文件是错误处理库的一部分。
类 | |
标准库组件抛出的各种异常的基类 (类) | |
(C++11) |
用于捕获并存储当前异常的混入类型 (类) |
当 std::current_exception 无法复制异常对象时抛出的异常 (类) | |
(C++17 中移除) |
std::unexpected 所调用的函数类型 (typedef) |
std::terminate 所调用的函数类型 (typedef) | |
(C++11) |
用于处理异常对象的共享指针类型 (typedef) |
函数 | |
(C++17 中移除) |
违背动态异常说明时调用的函数 (函数) |
(C++20 中移除)(C++17) |
检查当前是否正在进行异常处理 (函数) |
(C++11) |
从异常对象创建一个std::exception_ptr (函数模板) |
(C++11) |
捕获当前异常到 std::exception_ptr 之中 (函数) |
(C++11) |
从一个 std::exception_ptr 抛出异常 (函数) |
(C++11) |
抛出实参,带上混入的 std::nested_exception (函数模板) |
(C++11) |
抛出 std::nested_exception 中的异常 (函数模板) |
异常处理失败时调用的函数 (函数) | |
(C++11) |
获得当前的 terminate_handler (函数) |
更改将被 std::terminate 调用的函数 (函数) | |
(C++11)(C++17 中移除) |
获得当前的 unexpected_handler (函数) |
(C++17 中移除) |
更改要被 std::unexpected 调用的函数 (函数) |
概要
namespace std { class exception; class bad_exception; class nested_exception; using terminate_handler = void (*)(); terminate_handler get_terminate() noexcept; terminate_handler set_terminate(terminate_handler f) noexcept; [[noreturn]] void terminate() noexcept; int uncaught_exceptions() noexcept; using exception_ptr = /* 未指明 */; exception_ptr current_exception() noexcept; [[noreturn]] void rethrow_exception(exception_ptr p); template<class E> exception_ptr make_exception_ptr(E e) noexcept; template<class T> [[noreturn]] void throw_with_nested(T&& t); template<class E> void rethrow_if_nested(const E& e); }
类 std::exception
namespace std { class exception { public: exception() noexcept; exception(const exception&) noexcept; exception& operator=(const exception&) noexcept; virtual ~exception(); virtual const char* what() const noexcept; }; }
类 std::bad_exception
namespace std { class bad_exception : public exception { public: // 特殊成员函数的规定见 [exception] const char* what() const noexcept override; }; }
类 std::nested_exception
namespace std { class nested_exception { public: nested_exception() noexcept; nested_exception(const nested_exception&) noexcept = default; nested_exception& operator=(const nested_exception&) noexcept = default; virtual ~nested_exception() = default; // 访问函数 [[noreturn]] void rethrow_nested() const; exception_ptr nested_ptr() const noexcept; }; template<class T> [[noreturn]] void throw_with_nested(T&& t); template<class E> void rethrow_if_nested(const E& e); }