当派生类具有基类的多个副本时,将使用虚拟基类。
#include <iostream> using namespace std; class B { public: int b; }; class D1 : public B { public: int d1; }; class D2 : public B { public: int d2; }; class D3 : public D1, public D2 { public: int d3; }; int main() { D3 obj; obj.b = 40; //语句1,会出现错误 obj.b = 30; //语句2,会出现错误 obj.d1 = 60; obj.d2 = 70; obj.d3 = 80; cout<< "\n B : "<< obj.b cout<< "\n D1 : "<< obj.d1; cout<< "\n D2: "<< obj.d2; cout<< "\n D3: "<< obj.d3; }
在上面的例子中,D1和D2都继承了B,它们都有一个B的副本。但是,D3继承了D1和D2,因此D3有两个B副本,一个来自D1,另一个来自D2。
上面示例中的语句 1 和 2 将产生错误,因为编译器无法区分 D3 中 b 的两个副本。
要从 D3 中删除 B 的多个副本,我们必须将 D1 和 D3 中的 B 作为虚拟类继承。
因此,上面使用虚拟基类的示例将是 -
#include<iostream> using namespace std; class B { public: int b; }; class D1 : virtual public B { public: int d1; }; class D2 : virtual public B { public: int d2; }; class D3 : public D1, public D2 { public: int d3; }; int main() { D3 obj; obj.b = 40; // 陈述 3 obj.b = 30; // 陈述4 obj.d1 = 60; obj.d2 = 70; obj.d3 = 80; cout<< "\n B : "<< obj.b; cout<< "\n D1 : "<< obj.d1; cout<< "\n D2 : "<< obj.d2; cout<< "\n D3 : "<< obj.d3; }输出结果
B : 30 D1 : 60 D2 : 70 D3 : 80
现在,D3 只有 B 的一份副本,语句 4 将覆盖语句 3 中给出的 b 的值。