std::terminate
Defined in header <exception>
|
||
void terminate(); |
(until C++11) | |
[[noreturn]] void terminate() noexcept; |
(since C++11) | |
std::terminate()
is called by the C++ runtime when the program cannot continue for any of the following reasons:
5) a dynamic exception specification is violated and the default handler for std::unexpected is executed
6) a non-default handler for std::unexpected throws an exception that violates the previously violated dynamic exception specification, if the specification does not include std::bad_exception
|
(until C++17) |
7) a noexcept specification is violated (it is implementation-defined whether any stack unwinding is done in this case)
8) std::nested_exception::rethrow_nested is called for an object that isn't holding a captured exception
9) an exception is thrown from the initial function of std::thread
10) a joinable std::thread is destroyed or assigned to
11) std::condition_variable::wait, std::condition_variable::wait_until, or std::condition_variable::wait_for fails to reach its postcondition (e.g. if relocking the mutex throws)
|
(since C++11) |
12) a function invoked by a parallel algorithm exits via an uncaught exception and the execution policy specifies termination.
|
(since C++17) |
std::terminate()
may also be called directly from the program.
In any case, std::terminate
calls the currently installed std::terminate_handler. The default std::terminate_handler calls std::abort.
If a destructor reset the terminate handler during stack unwinding and the unwinding later led to |
(until C++11) |
If a destructor reset the terminate handler during stack unwinding, it is unspecified which handler is called if the unwinding later led to |
(since C++11) |
Parameters
(none)
Return value
(none)
Notes
If the handler mechanism is not wanted, e.g. because it requires atomic operations which may bloat binary size, a direct call to std::abort is preferred when terminating the program abnormally.
Some compiler intrinsics, e.g. __builtin_trap
(gcc, clang, and icc) or __debugbreak
(msvc), can be used to terminate the program as fast as possible.
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 2111 | C++11 | effect of calling set_terminate during stack unwinding differs from C++98 and breaks some ABIs
|
made unspecified |
See also
the type of the function called by std::terminate (typedef) | |
causes abnormal program termination (without cleaning up) (function) |