具有包含其他对象的类的对象创建顺序

Object creation order with class having containment of other objects

本文关键字:对象 创建 顺序 其他 包含      更新时间:2023-10-16
#include "iostream"
using namespace std;
class C
{
public:
C() { cout << "C's Constructor Called " << endl;  }
};
class A
{
public:
A() { cout << "A's Constructor Called " << endl;  }
A(int) {  cout << "A's int Constructor Called " << endl;  }
};
class B
{ 
public:
A a;
B() { cout << "B's Constructor Called " << endl; }
B(int i) : a(i) { cout << "B's int Constructor Called " << endl; }
C c;
};
int main()
{
B b1(1);
return 0;
}

输出:
A的int构造函数被调用
C的构造函数被调用

问题:
为什么输出不包含"A的构造函数Called">
据我所说,我认为输出如下:
A的构造函数Called
C的构造函数Called
B的int构造函数Called

想知道为什么由于(i(,A A不会导致调用构造函数A((,而只调用A(int(

C++总是只调用一个类的一个构造函数。

在您的情况下,编译器选择A(int)构造函数(因为这是您在B中使用的构造函数(,因此从不调用任何其他构造函数。

想知道为什么A A不会导致调用构造函数A((,而只会因为(i(而导致调用A(int(

A a;只是class B的字段成员的声明。这不会像本地声明那样初始化变量。相反,在执行a(i)时,初始化发生在B()构造函数中。这将调用A(int)构造函数。这里永远不会调用无参数构造函数。

A的构造函数未被调用,因为它被初始化列表中的参数化构造函数覆盖——B(int i(:A(i(。

如果你仔细观察"B的构造函数调用"也没有打印,因为同样的原因。

这只是因为您已经通过A的构造函数初始化了B的构造函数初始化器列表中的一个整数。

B(int i) : a(i) { cout << "B's int Constructor Called " << endl; }

你可以得到"调用了A的构造函数",如果你调用了它或没有初始化它,那么它就是默认初始化的:

B(int i) : a() { cout << "B's int Constructor Called " << endl; } // a is value-initialized which is here the same as default-initialized.