是跳过的非具体类的虚类的基构造函数
Are the base constructors of virtual class from non concrete classes skipped?
本文关键字:构造函数 更新时间:2023-10-16
我有这样的代码:
class Base{
public:
int x;
Base(int x){
this->x = x;
}
virtual ~Base(){
cout<<"base destroyed"<<endl;
}
};
class A: public virtual Base{
public:
A(int x) : Base(x){ //is this base call here skipped?
}
virtual ~A(){
cout<<"a has been destroyed"<<endl;
}
};
class B: public A{
public:
B():Base(10),A(12){ //initialized from here, overwrite attempt
}
};
int main(int argc, char** argv) {
B ey;
cout<<ey.x<<endl;
return 0;
}
我尝试在具体类的构造函数初始化时覆盖它:
B():Base(10),A(12){
输出仍然是10.
既然类A不是我的具体类,它是否跳过了基类的构造函数?
A(int x):Base(x){
虚基类仅由最派生类的构造函数构造,在本例中为B
。(它们恰好是在构造派生类的任何非虚直接基类之前先构造的。)
因为在你的例子中A
不是最派生的类,它的构造函数不构造虚基。
之所以会发生这种情况,是因为基类构造函数只会被调用一次。它不会被调用多次。首先,为对象分配内存,然后调用Base的构造函数,然后调用A的构造函数,最后调用B的构造函数。基本上,在为对象分配内存之后,遍历从根类开始的继承树,并执行特定于每个派生部分的构造。层次结构中每个类的构造函数将只被调用一次。因此,只有当我们在A的构造函数中再次修改x的值时,那么只有x的值在对象中发生了变化。
相关文章:
- "error: no matching function for call to"构造函数错误
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 选择要调用的构造函数
- 如何委托派生类使用其父构造函数?
- 构造函数正在调用一个使用当前类类型的函数
- 没有用于初始化C++中的变量模板的匹配构造函数
- 初始化具有非默认构造函数的std::数组项的更好方法
- 当从函数参数中的临时值调用复制构造函数时
- 在c++构造函数中使用随机字符串生成器
- 一对向量构造函数:初始值设定项列表与显式构造
- 从构造函数抛出异常时如何克服内存泄漏
- 我不明白为什么我声明一个空的内部结构并将其传递给构造函数
- 继承:构造函数,初始化C++11中基类的类C数组成员
- 具有默认模板类型的默认构造函数的类型推导
- 使用dynamic_cast和构造函数时出错
- 在c++中使用向量时,如何调用构造函数和析构函数
- 奇怪的构造函数行为