代码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、虚函数和虚基类的开销分析及使用指导》)。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。