Eccezione bad_cast

L'eccezione bad_cast viene generata dall'operatore dynamic_cast come risultato di un cast non riuscito a un tipo di riferimento.

Sintassi

catch (bad_cast)
   statement

Osservazioni:

L'interfaccia per bad_cast è:

class bad_cast : public exception

Il codice seguente contiene un esempio di errore dynamic_cast che genera l'eccezione 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();
   }
}

Viene generata l'eccezione perché l'oggetto sottoposto a cast (shape) non è derivato dal tipo di cast specificato (Circle). Per evitare l'eccezione, aggiungere tali dichiarazioni a main:

Circle circle_instance;
Circle& ref_circle = circle_instance;

Invertire quindi il senso del cast nel try blocco come segue:

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

Membri

Costruttori

Costruttore Descrizione
bad_cast Costruttore per oggetti di tipo bad_cast.

Funzioni

Funzione Descrizione
che cosa Da definire

Operatori

Operatore Descrizione
operator= Operatore di assegnazione che assegna un bad_cast oggetto a un altro.

bad_cast

Costruttore per oggetti di tipo bad_cast.

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

operator=

Operatore di assegnazione che assegna un bad_cast oggetto a un altro.

bad_cast& operator=(const bad_cast&) noexcept;

Dettagli

const char* what() const noexcept override;

Vedi anche

Operatore dynamic_cast
Parole chiave
Procedure consigliate C++ moderne per le eccezioni e la gestione degli errori