问题及代码:
#include <iostream>
using namespace std;
class Base
{
public:
Base(char i)
{
cout<<"Base constructor. --"<<i<<endl;
}
};
class Derived1:virtual public Base //虚基类
{
public:
Derived1(char i,char j):Base(i)
{
cout<<"Derived1 constructor. --"<<j<<endl;
}
};
class Derived2:virtual public Base //虚基类
{
public:
Derived2(char i,char j):Base(i)
{
cout<<"Derived2 constructor. --"<<j<<endl;
}
};
class MyDerived:public Derived1,public Derived2
{
public:
MyDerived(char i,char j,char k,char l,char m,char n,char x): Derived2(i,j), Derived1(k,l), Base(m), d(n)
{
cout<<"MyDerived constructor. --"<<x<<endl;
}
private:
Base d;
};
int main()
{
MyDerived obj('A','B','C','D','E','F','G');
/*
执行MyDerived的构造函数 Derived2('A','B'), Derived1('C','D'), Base('E'), d('F')
因为Derived2('A','B') 和 Derived1('C','D')为虚基类,所以先执行Base的构造函数 输出Base constructor. --E
然后进行虚基类的构造函数中自己的语句,先执行Derived1的构造函数,输出 Derived1 constructor. --D
再执行Derived2的构造函数,输出 Derived2 constructor. --B
然后MyDerived类内有个Base类的对象 ,所以再执行一次Base的构造函数,输出Base constructor. --F
最后是MyDerived构造函数内自己的语句 cout<<"MyDerived constructor. --G
*/
return 0;
}
运行结果:
知识点总结:
如上注释。
学习心得:
1.虚基类的定义
class 虚基类名:virtual public 所继承的基类。
2.在派生类继承了虚基类时,构造函数会先执行最初的基类的构造函数,并且在虚基类中会跳过基类中的数据成员的构造,执行自己的数据构造函数。