new[] 如果元素默认构造函数可以抛出
new[] if element default constructor can throw?
请考虑以下代码:
example_t* a = new example_t[8];
类 example_t
具有可以抛出的默认 ctor,假设在数组抛出中构造第 5 个元素。是否有自动调用前 4 个元素的析构函数?这是一个定义明确的行为吗?
这是完全定义和行为良好的。如果对象的初始化以异常终止,则所有完全构造的子对象都将销毁,顺序与其构造顺序相反。对于数组和用户定义类型的对象(想想类和类成员),这是相同的。
正式地,我们有 C++11 15.2/2:
任何存储持续时间的对象,其初始化或销毁因异常而终止,将 为其所有完全构造的子对象执行析构函数(不包括 类联合类),即对于主体构造函数 (12.6.2) 已完成执行的子对象 并且析构函数尚未开始执行。
根据 § 5.3.4/8:
新表达式通过调用 分配函数(3.7.4.1)。如果新表达式的结尾为 引发异常,它可能会通过调用 释放函数 (3.7.4.2)。如果分配的类型是非数组 类型,分配函数的名称为运算符 new,并且 释放函数的名称是运算符删除。如果分配的类型 是一种数组类型,分配函数的名称是运算符 new[] 和 释放函数的名称是运算符 delete[]。
它们将被删除,因为释放函数将调用析构函数。
我知道依靠编译器的输出是不可信的,但这至少是一个很好的观察: 实时测试
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 为什么不调用移动构造函数?(默认情况下只有构造器,没有别的)
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 基类中的默认析构函数禁用子类中的移动构造函数(如果有成员)
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 构造函数默认公共和私有变量
- 类模板构造函数默认参数
- 构造函数默认参数
- C++模板构造函数默认参数
- 在c++中设置构造函数默认值
- c++构造函数默认参数
- C++构造函数默认值头文件