来自异常声明的派生对象类型是否意外
Is a derived object type from the exception declaration unexpected?
在C++中,在异常声明说明符中,如果我声明一个基类,然后抛出一个派生类,这是一个意外的异常吗?
在C++中,在异常声明说明符中,如果我声明一个基类,然后抛出一个派生类,这是一个意外的异常吗?
不。这是允许的。
参考:C++03 15.4 异常规范
第6段:
异常规范可以多次包含同一类型,并且可以包含通过继承关联的类,即使这样做是多余的。异常规范还可以包括类 std::bad_exception (18.6.2.1)。
有一个
相关的例子在第8段:
[Example:
class X { };
class Y { };
class Z: public X { };
class W { };
void f() throw (X, Y)
{
int n = 0;
if (n) throw X(); // OK
if (n) throw Z(); // also OK <------- Example of the exact scenario you posted
throw W(); // will call unexpected()
}
—end example]
请注意,异常规范被视为失败的实验,大多数编译器未正确实现它们。所以避免(宁愿不要)使用它们。
我知道
这是可怕的非答案,但请不要使用异常规范:
http://www.gotw.ca/publications/mill22.htm
引用相关部分:
道德#1:永远不要编写异常规范。
道德#2:除了可能空的,但如果我是你,我甚至会避免。
#2 的警告是 C++11 中的"noexcept"。
相关文章:
- 在 C++ 中将一个模板类型的对象类型转换为另一个模板类型
- 了解 Python 中的对象类型
- 具有纯虚函数和指针数组对象类型的父类的指针数组
- 调用的对象类型 'double' 不是 report() 函数的函数或函数指针
- 基准、值、值类型、对象和对象类型(C++)
- JNI 如何将 Java 对象数组传递给相同对象类型的 C++ 数组
- 在构造过程中更改的对象类型
- 如何构建程序以避免查询对象类型?
- 如何使用Dynamic_cast获得对象类型
- 什么更有效率?在重载函数中或通过在基类函数中检查对象类型来实现
- static_cast实际上不是对象类型的类型是未定义的行为吗?
- 为什么 std::variant 不能容纳数组对象类型,而联合可以?
- 为什么类型转换对象不会更改其地址?有关对象类型的信息存储在哪里?
- 类返回对象类型,但如何返回和检查 null
- 是否可以在辅助功能中概括对象类型
- 表达式必须在C 中具有指针对象类型
- 下标需要数组或指针类型表达式必须具有指针对象类型
- 当将对象传递给具有参数作为引用类型的函数以及当其类对象类型时,会得到不同的输出
- 如何在运行时指定对象类型
- 我可以获取在重载的新运算符中使用新运算符的对象类型吗?