解析C++编程中的bad_cast异常
更新时间:2016年01月15日 16:14:55 投稿:goldensun
这篇文章主要介绍了C++编程中的bad_cast异常,bad_cast异常通常出现于表达式中类型转换错误时等一些场景,需要的朋友可以参考下
由于强制转换为引用类型失败,dynamic_cast 运算符引发 bad_cast 异常。
语法
catch (bad_cast) statement
备注
bad_cast 的接口为:
class bad_cast : public exception {
public:
bad_cast(const char * _Message = "bad cast");
bad_cast(const bad_cast &);
virtual ~bad_cast();
};
以下代码包含失败的 dynamic_cast 引发 bad_cast 异常的示例。
// expre_bad_cast_Exception.cpp
// compile with: /EHsc /GR
#include <typeinfo.h>
#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();
}
}
由于强制转换的对象 (Shape) 不是派生自指定的强制转换类型 (Circle),因此引发异常。若要避免此异常,请将下列声明添加到 main:
Circle circle_instance; Circle& ref_circle = circle_instance;
然后在 try 块中反转强制转换的意义,如下所示:
Shape& ref_shape = dynamic_cast<Shape&>(ref_circle);
相关文章
c++如何控制对象的创建方式(禁止创建栈对象or堆对象)和创建的数量
这篇文章主要介绍了c++如何控制对象的创建方式和创建的数量,帮助大家更好的理解和学习,感兴趣的朋友可以了解下2020-08-08
C语言二叉树常见操作详解【前序,中序,后序,层次遍历及非递归查找,统计个数,比较,求深度】
这篇文章主要介绍了C语言二叉树常见操作,结合实例形式详细分析了基于C语言的二叉树前序,中序,后序,层次遍历及非递归查找,统计个数,比较,求深度等相关操作技巧与注意事项,需要的朋友可以参考下2018-04-04


最新评论