虚拟继承构造函数选择
Virtual inheritance constructor selection
为什么要打印 20000?代码在继承序列中一直显式调用特定的基础构造函数,但忽略指定的构造函数并改用默认构造函数。
#include <iostream>
struct Car
{
Car() : price(20000) {}
Car(double b) : price(b*1.1) {}
double price;
};
struct Toyota : public virtual Car
{
Toyota(double b) : Car(b) {}
};
struct Prius : public Toyota
{
Prius(double b) : Toyota(b) {}
};
int main(int argc, char** argv)
{
Prius p(30000);
std::cout << p.price << std::endl;
return 0;
}
虚基class必须由最派生class构造;考虑到菱形层次结构的可能性,这是唯一有意义的方法。
在您的例子中,Prius
使用其默认构造函数构造 Car
。如果你想要另一个构造函数,你必须显式调用它,如
Prius(double b) : Car(b), Toyota(b) {}
为什么要打印 20000?代码在继承序列中一直显式调用特定的基础构造函数,但忽略指定的构造函数并改用默认构造函数。
#include <iostream>
struct Car
{
Car() : price(20000) {}
Car(double b) : price(b*1.1) {}
double price;
};
struct Toyota : public virtual Car
{
Toyota(double b) : Car(b) {}
};
struct Prius : public Toyota
{
Prius(double b) : Toyota(b) {}
};
int main(int argc, char** argv)
{
Prius p(30000);
std::cout << p.price << std::endl;
return 0;
}
虚基class必须由最派生class构造;考虑到菱形层次结构的可能性,这是唯一有意义的方法。
在您的例子中,Prius
使用其默认构造函数构造 Car
。如果你想要另一个构造函数,你必须显式调用它,如
Prius(double b) : Car(b), Toyota(b) {}