Namespaces
Variants

std:: bad_any_cast

From cppreference.net
Utilities library
Definido en el encabezado <any>
class bad_any_cast : public std:: bad_cast
(desde C++17)

Define un tipo de objeto que será lanzado por las formas que retornan valor de std::any_cast en caso de fallo.

Contenidos

Funciones miembro

(constructor)
construye un nuevo objeto bad_any_cast
(función miembro pública)
operator=
reemplaza el objeto bad_any_cast
(función miembro pública)
what
devuelve la cadena explicativa
(función miembro pública)

std::bad_any_cast:: bad_any_cast

bad_any_cast ( ) noexcept ;
(1) (desde C++17)
bad_any_cast ( const bad_any_cast & other ) noexcept ;
(2) (desde C++17)

Construye un nuevo objeto bad_any_cast con una cadena de bytes terminada en nulo definida por la implementación, accesible mediante what() .

1) Constructor por defecto.
2) Constructor de copia. Si * this y other tienen ambos tipo dinámico std::bad_any_cast entonces std:: strcmp ( what ( ) , other. what ( ) ) == 0 .

Parámetros

other - otro objeto de excepción a copiar

std::bad_any_cast:: operator=

bad_any_cast & operator = ( const bad_any_cast & other ) noexcept ;
(desde C++17)

Asigna los contenidos con los de other . Si * this y other ambos tienen tipo dinámico std::bad_any_cast entonces std:: strcmp ( what ( ) , other. what ( ) ) == 0 después de la asignación.

Parámetros

other - otro objeto de excepción con el cual asignar

Valor de retorno

* this

std::bad_any_cast:: what

virtual const char * what ( ) const noexcept ;
(desde C++17)

Devuelve la cadena explicativa.

Valor de retorno

Puntero a una cadena terminada en nulo definida por la implementación con información explicativa. La cadena es adecuada para conversión y visualización como std::wstring . Se garantiza que el puntero será válido al menos hasta que se destruya el objeto de excepción del cual se obtiene, o hasta que se llame a una función miembro no constante (por ejemplo, el operador de asignación de copia) en el objeto de excepción.

Notas

Las implementaciones pueden, pero no están obligadas, a sobrescribir what() .

Heredado de std:: bad_cast

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 )

Ejemplo

#include <any>
#include <cassert>
#include <print>
int main()
{
    auto x = std::any(42);
    assert(std::any_cast<int>(x) == 42); // OK
    try
    {
        [[maybe_unused]] auto s = std::any_cast<std::string>(x); // lanza excepción
    }
    catch (const std::bad_any_cast& ex)
    {
        std::println("{}", ex.what());
    }
}

Salida posible:

bad any_cast