否,除非函数返回具有抛出析构函数的类
noexcept of a function returning a class having throwing destructor
在下面的代码中,我认为断言不应该触发,但它确实触发了。
struct A
{
~A() noexcept(false);
};
A f() noexcept;
int main()
{
static_assert(noexcept(f()), "f must be noexcept");
}
函数f()
显然是 no,但noexcept(f())
的计算结果为 false。(在海湾合作委员会和叮当声中)
我错过了什么还是错误?
表达式
e
上的noexcept
运算符告诉您表达式的潜在异常集是否为空。此集合包含析构函数的潜在异常,如 [except.spec]/(13.2):
如果
e
隐式调用一个或多个函数(例如重载运算符、新表达式中的分配函数或析构函数(如果 e 是完整表达式 (1.9)),则 S 是以下的并集:[...] 所有此类函数的异常规范中的类型集
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- C++成员的析构函数顺序与shared_ptr
- C++ 防止在映射中放置()时调用析构函数
- 在这种情况下显式调用时,std::cout 如何更改析构函数的行为?
- 调用析构函数以释放动态分配的内存
- 不命名构造函数和析构函数上的类型错误