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

发表回复