B和C从A中继承,而D多重继承于B,C。那就意味着D中会有A中的两个拷贝。因为成员函数不体现在类的内存大小上,所以实际上可以看到的情况是D的内存分布中含有2组A的成员变量。
#include<iostream>
using namespace std;
class Animal
{
public:
int m_Age;
};
class Sheep :public Animal
{
};
class Tuo :public Animal
{
};
class SheepTuo :public Sheep, public Tuo
{
};
void test()
{
SheepTuo st;
//st.m_Age=66;有问题,会出现二义性,想修改数值的话必须加上作用域
st.Sheep::m_Age = 18;
st.Tuo::m_Age = 30;
cout << "Sheep::m_Age" << st.Sheep::m_Age<<endl;
cout << "Tuo::m_Age" << st.Tuo::m_Age<<endl;
}
int main()
{
test();
system("pause");
return 0;
}
改进方法:利用虚继承
#include<iostream>
using namespace std;
class Animal
{
public:
int m_Age;
};
//利用虚继承, 解决菱形继承的问题
//继承之前 加上关键字 virtual 变为虚继承
//Animal类称为 虚基类
class Sheep :virtual public Animal{};
class Tuo :virtual public Animal{};
class SheepTuo :public Sheep, public Tuo{};
void test()
{
SheepTuo st;
st.m_Age = 66;
cout << "Sheep::m_Age:--" << st.Sheep::m_Age<<endl;
cout << "Tuo::m_Age:--" << st.Tuo::m_Age<<endl;
cout << "m_Age:--" << st.m_Age << endl;
cout << sizeof(Sheep) << endl;
cout << sizeof(Tuo) << endl;
cout << sizeof(SheepTuo) << endl;
}
int main()
{
test();
system("pause");
return 0;
}
虚继承是解决C++多重继承问题的一种手段,从不同途径继承来的同一基类,会在子类中存在多份拷贝。这将存在两个问题:其一,浪费存储空间;第二,存在二义性问题,通常可以将派生类对象的地址赋值给基类对象,实现的具体方式是,将基类指针指向继承类(继承类有基类的拷贝)中的基类对象的地址,但是多重继承可能存在一个基类的多份拷贝,这就出现了二义性。