std::exception::exception

From cppreference.com
< cpp‎ | error‎ | exception
 
 
Utilities library
General utilities
Date and time
Function objects
Formatting library (C++20)
(C++11)
Relational operators (deprecated in C++20)
Integer comparison functions
(C++20)(C++20)(C++20)   
(C++20)
Swap and type operations
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Common vocabulary types
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Elementary string conversions
(C++17)
(C++17)
 
Diagnostics library
Exception handling
Exception handling failures
(until C++17*)
(until C++17*)
(C++11)(until C++17*)    
(until C++17*)
Error codes
Error codes
 
 
(1)
exception() throw();
(until C++11)
exception() noexcept;
(since C++11)
(2)
exception( const exception& other ) throw();
(until C++11)
exception( const exception& other ) noexcept;
(since C++11)

Constructs new exception object.

1) Default constructor. what() returns an implementation-defined string.
2) Copy constructor. Initializes the contents with those of other. If *this and other both have dynamic type std::exception then std::strcmp(what(), other.what()) == 0.

Parameters

other - another exception to assign the contents of

Notes

Because copying std::exception is not permitted to throw exceptions, when derived classes (such as std::runtime_error) have to manage a user-defined diagnostic message, it is typically implemented as a copy-on-write string.

The Microsoft implementation includes non-standard constructors taking strings thus allowing instances to be thrown directly with a meaningful error message. The nearest standard equivalents are std::runtime_error or std::logic_error.

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 471 C++98 there is no requirement on what() of the exception copy added