#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.