<十>关于菱形继承

代码1

#include <iostream>
using namespace std;
	
class A{

public:
	
 A(int _a):ma(_a){
   cout<<"A()"<<endl;
 }
	
 ~A(){
   cout<<"~A()"<<endl;
 }
	
protected:
	int ma;

};	

class B : public  A{

public:
	
 B(int _b):A(_b),mb(_b){
   cout<<"B()"<<endl;
 }
	
 ~B(){
   cout<<"~B()"<<endl;
 }
		
protected:
	int mb;

};	

class C : public  A{

public:
	
 C(int _c):A(_c),mc(_c){
   cout<<"C()"<<endl;
 }
	
 ~C(){
   cout<<"~C()"<<endl;
 }
		
protected:
	int mc;

};	

class D : public  B, C{

public:
	
 D(int _d):B(_d),C(_d),md(_d){
   cout<<"D()"<<endl;
 }
	
 ~D(){
   cout<<"~D()"<<endl;
 }
		
protected:
	int md;

};

	
int main(){
   D d(100);
 
  return 0;
}

//代码执行顺序
A()
B()
A()
C()
D()
~D()
~C()
~A()
~B()
~A()

D的内存结构

发现有重复的 数据 ma

为了解决上面的问题,引入虚继承

代码2

#include <iostream>
using namespace std;
	
class A{

public:
	
 A(int _a):ma(_a){
   cout<<"A()"<<endl;
 }
	
 ~A(){
   cout<<"~A()"<<endl;
 }
	
protected:
	int ma;

};	

class B : virtual public  A{

public:
	
 B(int _b):A(_b),mb(_b){
   cout<<"B()"<<endl;
 }
	
 ~B(){
   cout<<"~B()"<<endl;
 }
		
protected:
	int mb;

};	

class C : virtual public  A{

public:
	
 C(int _c):A(_c),mc(_c){
   cout<<"C()"<<endl;
 }
	
 ~C(){
   cout<<"~C()"<<endl;
 }
		
protected:
	int mc;

};	

class D : public  B, C{

public:
	
 D(int _d):A(_d),B(_d),C(_d),md(_d){
   cout<<"D()"<<endl;
 }
	
 ~D(){
   cout<<"~D()"<<endl;
 }
		
protected:
   int md;

};
	
int main(){
   D d(100);
 
  return 0;
}
//执行结果
A()
B()
C()
D()
~D()
~C()
~B()
~A()

//A的构造有D 来完成 B和C下面有各自的vbptr 定位得基类数据

虚继承用来解决多重继承中遇到的多份数据的问题

虚拟继承在一般的应用中很少用到,所以也往往被忽视,这也主要是因为在C++中,多重继承是不推荐的,也并不常用,而一旦离开了多重继承,虚拟继承就完全失去了存在的必要(因为这样只会降低效率和占用更多的空间,关于这一点,我自己还没有太多深刻的理解,有兴趣的可以看网络上白杨的作品《RTTI、虚函数和虚基类的开销分析及使用指导》)。

posted @ 2022-11-29 21:52  Hello_Bugs  阅读(71)  评论(0编辑  收藏  举报