博客
关于我
C++面向对象(十一)多继承
阅读量:124 次
发布时间:2019-02-27

本文共 814 字,大约阅读时间需要 2 分钟。

关键词:虚基类、vbptr、多继承

例如菱形继承存在的问题:在这里插入图片描述

问题:对于A类中的数据,D类中会有俩份相同的拷贝,这样势必会浪费内存空间

怎么解决?

1.所有从该基类(A)直接继承的派生类(B,C),都应该采用 virtual虚继承
2.在最终的派生类中指定虚基类的构造方式,在派生类构造函数的初始化列表中指定

虚继承: 例如 class B : virtual public A 表示虚继承

class A{public:	A(int data) :ma(data){ cout << "A()" << endl; }	~A(){ cout << "~A()" << endl; }	int ma;};class B : virtual  public A{public:	B(int data):A(data), mb(data){ cout << "B()" << endl; }	~B(){ cout << "~B()" << endl; }	int mb;};class C :virtual  public A{public:	C(int data) :A(data), mc(data){ cout << "C()" << endl; }	~C(){ cout << "~C()" << endl; }	int mc;};class D : public B, public C{public:	D(int data) :C(data), B(data), A(data), md(data)	{ cout << "D()" << endl; }	~D(){ cout << "~D()" << endl; }	int md;};

再来看一下内存布局是怎么布局的?

在这里插入图片描述

A既然跑到派生类内存的最后面了,是不是就是最后构造?

构造顺序仍然是: 虚基类先构造(A), 直接基类按继承顺序构造(B,C), 派生类自己构造(D)

转载地址:http://jmyd.baihongyu.com/

你可能感兴趣的文章
Mysql索引类型
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
mysql索引能重复吗_mysql “索引”能重复吗?“唯一索引”与“索引”区别是什么?...
查看>>
MySQL索引详解(IT枫斗者)
查看>>
MySQL索引那些事:什么是索引?为什么加索引就查得快了?
查看>>
Mysql索引(1):索引概述
查看>>
Mysql索引(2):索引结构
查看>>
Mysql索引(3):索引分类
查看>>
Mysql索引(4):索引语法
查看>>
mysql级联删除_Mysql笔记系列,DQL基础复习,Mysql的约束与范式
查看>>
mysql练习语句
查看>>
mysql经常使用命令
查看>>
MySQL经常使用技巧
查看>>
mysql给root开启远程访问权限,修改root密码
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql编写存储过程
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql网络部分代码
查看>>