Namespaces
Variants

std:: bad_exception

From cppreference.net
Utilities library
Definido en el encabezado <exception>
class bad_exception : public exception

std::bad_exception es el tipo de excepción lanzada por el runtime de C++ en las siguientes situaciones:

  • Si std::exception_ptr almacena una copia de la excepción capturada y si el constructor de copia del objeto de excepción capturado por std::current_exception lanza una excepción, la excepción capturada es una instancia de std::bad_exception .
(desde C++11)
(hasta C++17)
cpp/error/exception std-bad exception-inheritance.svg

Diagrama de herencia

Todas las funciones miembro de std::bad_exception son constexpr .

(desde C++26)

Contenidos

Funciones miembro

construye el objeto bad_exception
(función miembro pública)
copia el objeto
(función miembro pública)
[virtual]
devuelve la cadena explicativa
(función miembro pública virtual)

Heredado de std:: exception

Funciones miembro

[virtual]
destruye el objeto de excepción
(función miembro pública virtual de std::exception )
[virtual]
devuelve una cadena explicativa
(función miembro pública virtual de std::exception )

Notas

Macro de prueba de características Valor Std Característica
__cpp_lib_constexpr_exceptions 202411L (C++26) constexpr para tipos de excepción

Ejemplo

Solo compila en modos C++14 o anteriores (puede generar advertencias).

#include <exception>
#include <iostream>
#include <stdexcept>
void my_unexp()
{
    throw;
}
void test()
    throw(std::bad_exception) // Dynamic exception specifications
                              // are deprecated in C++11
{
    throw std::runtime_error("test");
}
int main()
{
    std::set_unexpected(my_unexp); // Deprecated in C++11, removed in C++17
    try
    {
        test();
    }
    catch (const std::bad_exception& e)
    {
        std::cerr << "Caught " << e.what() << '\n';
    }
}

Salida posible:

Caught std::bad_exception