目录
简介
两个派生类继承同一个基类,又有某个类同时继承了两个派生类,这种继承称为菱形继承或者钻石继承。
菱形继承产生的问题:
设基类为A ,继承基类的两个子类为B、C,有D同时继承B、C
1.B、C都继承了A的数据,当D使用数据时会产生二义性
2.D继承了A的两份数据,我们只需要一份
虚继承解决菱形继承问题
关于虚继承的几点注意事项
1.在多继承情况下,虚基类关键字virtual只对紧跟其后的基类起作用。声明了虚基类之后,虚基类的成员在进一步派生过程中和派生类一起维护同一个内存数据拷贝。
2.建立对象时所指定的类称为最(远)派生类。虚基类成员是由最派生类的构造函数通过调用虚基类的构造函数进行初始化的。
3.在整个继承结构中,直接或间接继承虚基类的所有派生类,都必须在构造函数的成员初始化列表中给出对虚基类的构造函数的调用。如果未列出,则表示调用该虚基类的缺省构造函数。在建立对象时,只有最派生类的构造函数调用虚基类的构造函数,该派生类的其它基类对虚基类构造函数的调用被忽略。
案例
#include<iostream>
using namespace std;
class B0
{
public:
B0(int n) {
nV = n;
}
int nV;
void fun() {
cout << "Memeber of B0" << endl;
}
};
class B1 :virtual public B0
{
public:
B1(int a):B0(a){}
int nV1;
};
class B2 :virtual public B0
{
public:
B2(int a):B0(a){}
int nV2;
};
class D1 :public B1, public B2
{
public:
D1(int a):B0(a),B1(a),B2(a){}
int nVd;
void fund() {
cout << "Memver of D1" << endl;
}
};
int main()
{
D1 d(1);
cout << d.nV << endl;
d.fun();
return 0;
}