通过值初始化的规则。值初始化发生:
1,5) 当使用由一对空括号或花括号组成的初始化程序创建无名临时对象时 (C++11 起);
2,6) 当具有动态存储持续时间的对象由 new 表达式创建时,初始化器由一对空括号或大括号组成 (C++11 起);
3,7) 当非静态数据成员或基类使用带有一对空括号或大括号的成员初始化程序进行初始化时 (C++11 起);
4) 当一个命名变量(自动的、静态的或线程局部的)用由一对大括号组成的初始化器声明时。
简单的例子
struct A{
int i;
string s;
A(){};
};
A a{}
cout << a.i << endl // default initialized value
没有显式声明的构造函数并留下默认的默认 ctor // 编译器生成我们得到的一个。
struct A{
int i;
string s;
};
A a{};
cout << a.i << endl // zero-initialized value
但是使用另一个结构。
struct A{
int i;
string s;
};
struct B{
A a;
int c;
};
B a{};
cout << a.a.i << endl // default initialized , even tho we did not , int struct B , declared A a{}.
ai 的值是零初始化的,即使没有使用 {} / () 构造,这违反了规则(如果我没记错的话)。
在结构 B 上使用相同的逻辑:
struct A{
int i;
string s;
};
struct B{
A a;
int c;
};
B b;
cout << b.c << endl; // default inicialized
我们根据规则获得行为。
最后一个例子:
struct A
{
int i;
A() { }
};
struct B { A a; };
std::cout << B().a.i << endl;
B().ai 也是零初始化的,而我们显式声明了构造函数并且它没有被删除。
为什么这些值被零初始化?根据此处规定的规则,它们应该是默认初始化而不是零初始化。
感谢您的回答。