隐式字段初始化的规则
Rules for on implicit fields initialization
我最近修复了我的一个应用程序中的一个错误:问题是驻留在堆栈上的对象有一个未初始化的字段。
该对象具有以下类型的类声明:
struct A{
int somefield, someotherfield;
A(): someotherfield(0) {}
}
当声明局部变量(如函数中的A var;
)时,somefield
未初始化,因此读取它将返回随机值。
我确信未出现在构造函数初始化列表中的类字段总是由合成的普通构造函数初始化(在 int 的情况下为零值)。显然我错了。
那么隐式字段初始化的一般规则是什么?
- 类和结构由构造器初始化
- 基本类型int双字符短...未初始化且包含随机数
- 指针未初始化并指向随机位置
- 类或结构数组导致每个元素由其构造函数初始化
- 基本类型或指针的数组是随机的。
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 变量可能尚未初始化[MIRA 2012规则9.1,强制性]
- 直接列表初始化的自动规则
- 类静态变量初始化的规则是什么?
- 初始化中的模板转换运算符类型推导规则是什么?
- 为什么当它打破初始化列表的顺序规则时它会起作用
- 新标准中对memcpy生命周期初始化规则有哪些更改(如果有的话)
- 列表初始化中多个模板构造函数的过载规则
- 隐式字段初始化的规则