为什么在虚拟继承中调用Default构造函数?

时间:2012-03-28 12:42:15

标签: c++ inheritance virtual-inheritance

我不明白为什么在以下代码中,当我实例化daughter类型的对象时,会调用默认的grandmother()构造函数?

我认为应该调用grandmother(int)构造函数(遵循我的mother类构造函数的规范),或者由于虚拟继承,这段代码根本不应该编译。

这里编译器在我的后面静默调用grandmother默认构造函数,而我从来没有要求它。

#include <iostream>

class grandmother {
public:
    grandmother() {
        std::cout << "grandmother (default)" << std::endl;
    }
    grandmother(int attr) {
        std::cout << "grandmother: " << attr << std::endl;
    }
};

class mother: virtual public grandmother {
public:
    mother(int attr) : grandmother(attr) {
        std::cout << "mother: " << attr << std::endl;
    }
};

class daughter: virtual public mother {
public:
    daughter(int attr) : mother(attr) {
        std::cout << "daughter: " << attr << std::endl;
    }
};

int main() {
  daughter x(0);
}

1 个答案:

答案 0 :(得分:76)

使用虚拟继承时,虚拟基类的构造函数由最派生类的构造函数直接调用。在这种情况下,daughter构造函数直接调用grandmother构造函数。

由于您没有在初始化列表中显式调用grandmother构造函数,因此将调用默认构造函数。要调用正确的构造函数,请将其更改为:

daugther(int attr) : grandmother(attr), mother(attr) { ... }

另见This FAQ entry