C++在初始化列表外显式调用父构造函数

C++ explicitly call parent constructor outside initialization list

本文关键字:调用 构造函数 初始化 列表 C++      更新时间:2023-10-16

因此,调用父类构造函数的普通方法在初始化列表中:

例如

#include <cstdio>
struct Parent {
explicit Parent(int a) {
printf("Parent -- intn");
}
};
struct Child : public Parent {
explicit Child(int a) : Parent(1) {
printf("Child -- intn");
}
};
int main(int argc, char **argv) {
Child c = Child(10);
};

打印CCD_ 1然后打印Child -- int

(有点)不管这是否是个好主意,我想知道是否可以在初始化列表之外的构造函数主体(在正在构造的对象上)中显式调用父构造函数。

没有,不是按照您想要的方式,所以它构造了对象的父部分。

处理这种情况的常见方法是有一个"init"或"construct"方法,然后可以从子构造函数调用:

struct Parent {
explicit Parent(int a) {
Construct(a);
}
protected:
void Construct(int a) { printf("Parent -- intn"); }
Parent() {}
};
struct Child : public Parent {
explicit Child(int a) {
Parent::Construct(a);
printf("Child -- intn");
}
};
int main(int argc, char **argv) {
Child c = Child(10);
};

好吧,可以,但它不会做同样的事情。

例如

explicit Child(int) {
Parent(1);
}

将不会初始化对象的CCD_ 3部分。相反,它将创建一个类型为Parent的新临时对象,然后该临时对象将立即被销毁。