1:分析菱形继承的问题。
2:剖析虚继承是怎么解决二义性和数据冗余的。
首先,我们介绍什么是 菱形继承:
插入一段代码:
#include<iostream>
using namespace std;
class A
{
protected:
int _a;
public:
void fun()
{
cout << "A::fun" << endl;
}
};
class B:public A
{
protected:
int _b;
};
class C : public A
{
protected:
int _c;
};
class D :public B, public C
{
private:
int _d;
};
int main()
{
D d;
d.A::fun();
d.B::fun();
}
我们可以看见D的对象模型里面保存了两份A,当我们想要调用我们从A里继承的fun时就会出现调用不明确问题,并且会造成数据冗余的问题,明明可以只要一份就好,而我们却保存了两份。可见菱形继承十分不便,具有二义性和数据冗余的特性。
所以,我们引出解决菱形继承二义性和数据冗余的方法——虚继承
虚继承:
虚继承即让B和C在继承A时加上virtural关键字,如下:
#include<iostream>
using namespace std;
class A
{
protected:
int _a;
public:
void fun()
{
cout << "A::fun" << endl;
}
};
class B:virtual public A
{
protected:
int _B;
};
class C :virtual public A
{
protected:
int _C;
};
class D :public B, public C
{
private:
int _d;
};
int main()
{
D d;
d.fun();
getchar();
}
那 虚继承 又是怎么做的呢?
我们可看见在B和C中不再保存A中的内容,保存了一份偏移地址,然后将A的数据保存在一个公共位置处这样保证了数据冗余性的降低同时,我们也能直接的使用d.fun()来调用A里的fun函数。