C++在初始化列表外显式调用父构造函数
C++ explicitly call parent constructor outside initialization list
因此,调用父类构造函数的普通方法在初始化列表中:
例如
#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
的新临时对象,然后该临时对象将立即被销毁。
相关文章:
- 在c++中使用向量时,如何调用构造函数和析构函数
- C++:考虑但不调用构造函数的特殊性
- 对象实例化调用构造函数的次数太多
- 我使用向量来创建类对象列表.初始化向量时如何使用参数调用构造函数?
- C ++:通过大括号调用构造函数?
- 不能调用构造函数
- 赋值 boost::intrusive_ptr 而不调用构造函数?
- 在模板化类的构造函数中调用构造函数
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- 为什么从另一个构造函数内部调用C++构造函数不修改类变量?
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- 有没有一种简单的方法可以在对象向量上调用构造函数?
- 我不明白在这个例子中什么时候调用构造函数
- 调用c++构造函数的不同方法
- 调用构造函数与将内联常量定义为默认参数
- 如何通过 Rust FFI 调用C++构造函数?
- "new"运算符是否总是调用构造函数?
- 无法调用构造函数
- 使用 "()" 调用构造函数不同于"{}"
- 确定是调用构造函数还是强制转换运算符的因素