标签:
问题及代码:
#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.在派生类继承了虚基类时,构造函数会先执行最初的基类的构造函数,并且在虚基类中会跳过基类中的数据成员的构造,执行自己的数据构造函数。
标签:
原文地址:http://blog.csdn.net/destiny_forever/article/details/46042011