bad_cast exception
The bad_cast exception is thrown by the dynamic_cast
operator as the result of a failed cast to a reference type.
Syntax
catch (bad_cast)
statement
Remarks
The interface for bad_cast is:
class bad_cast : public exception
The following code contains an example of a failed dynamic_cast
that throws the bad_cast exception.
// 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();
}
}
The exception is thrown because the object being cast (a Shape) isn't derived from the specified cast type (Circle). To avoid the exception, add these declarations to main
:
Circle circle_instance;
Circle& ref_circle = circle_instance;
Then reverse the sense of the cast in the try
block as follows:
Shape& ref_shape = dynamic_cast<Shape&>(ref_circle);
Members
Constructors
Constructor | Description |
---|---|
bad_cast | The constructor for objects of type bad_cast . |
Functions
Function | Description |
---|---|
what | TBD |
Operators
Operator | Description |
---|---|
operator= | An assignment operator that assigns one bad_cast object to another. |
bad_cast
The constructor for objects of type bad_cast
.
bad_cast(const char * _Message = "bad cast");
bad_cast(const bad_cast &);
operator=
An assignment operator that assigns one bad_cast
object to another.
bad_cast& operator=(const bad_cast&) noexcept;
what
const char* what() const noexcept override;
See also
dynamic_cast Operator
Keywords
Modern C++ best practices for exceptions and error handling