在多重继承中,如果发生了如:类B继承类A,类C继承类A,类D同时继承了类B和类C。最终在类D中就有了两份类A的成员,这在程序中是不能容忍的。当然解决这个问题的方法就是利用虚继承。
class A{
public:
int t;
A(int a)
{
t = a;
}
void fun();
};
class B:virtual public A
{
public:
B(int a, int b) :A(a+10)
{
t1 = b;
}
~B();
int t1;
};
class C :virtual public A
{
public:
C(int a,int c):A(a+20)
{
t2 = c;
}
~C();
int t2;
};
class D :public B,public C
{
public:
D(int a,int b,int c,int d) :B(a,b),C(a,c),A(a){}//在此必须要给虚基类传参
~D();
};
在派生时将关键字virtual加在相应相应继承方式前,就可防止在D类中同时出现两份A类成员。
在实例化D时我们给a传入一个1,那么在虚基类中的t为何值呢?(注意我们在第14,25行给虚基类的构造函数传值时都进行了“+”操作。)
而答案是肯定的必然为1,因为在实例化D的时候,只会调用一次虚基类的构造函数,使得虚基类接收到参数也只可能是从实例化D时传过来的参数。
int mian()
{
D temp(1,2,3,4);
return 0;
}
注意:C++编译系统在实例化D类时,只会将虚基类的构造函数调用一次,忽略虚基类的其他派生类(class B,class C)对虚继承的构造函数的调用,从而保证了虚基类的数据成员不会被多次初始化。