Compartir a través de


bad_cast (Excepción)

El operador dynamic_cast inicia la excepción bad_cast como resultado de una conversión incorrecta a un tipo de referencia.

Sintaxis

catch (bad_cast)
   statement

Comentarios

La interfaz para bad_cast es:

class bad_cast : public exception

El código siguiente contiene un ejemplo de dynamic_cast con errores que inicia la excepción bad_cast.

// expre_bad_cast_Exception.cpp
// compile with: /EHsc /GR
#include <typeinfo>
#include <iostream>

class Shape {
public:
   virtual void virtualfunc() const {}
};

class Circle: public Shape {
public:
   virtual void virtualfunc() const {}
};

using namespace std;
int main() {
   Shape shape_instance;
   Shape& ref_shape = shape_instance;
   try {
      Circle& ref_circle = dynamic_cast<Circle&>(ref_shape);
   }
   catch (bad_cast b) {
      cout << "Caught: " << b.what();
   }
}

Se inicia una excepción porque el objeto que se convierte (una forma) no se deriva del tipo de conversión especificado (círculo). Para evitar la excepción, agregue estas declaraciones a main:

Circle circle_instance;
Circle& ref_circle = circle_instance;

A continuación, invierta el sentido de la conversión en el bloque try de la siguiente manera:

Shape& ref_shape = dynamic_cast<Shape&>(ref_circle);

Miembros

Constructores

Constructor Descripción
bad_cast Constructor para los objetos de tipo bad_cast.

Funciones

Función Descripción
qué Por determinar

Operadores

Operador Descripción
operator= Operador de asignación que asigna un objeto bad_cast a otro.

bad_cast

Constructor para los objetos de tipo bad_cast.

bad_cast(const char * _Message = "bad cast");
bad_cast(const bad_cast &);

operator=

Operador de asignación que asigna un objeto bad_cast a otro.

bad_cast& operator=(const bad_cast&) noexcept;

qué

const char* what() const noexcept override;

Consulte también

dynamic_cast (Operador)
Palabras clave
Procedimientos recomendados de C++ moderno para las excepciones y el control de errores