C++多继承时的对象内存模型
#include <cstdio>
#include <iostream>
using namespace std;
//基类A
class A{
public:A(int a, int b);public:int m_a;int m_b;
};
A::A(int a, int b): m_a(a), m_b(b){ }
//基类B
class B{
public:B(int b, int c);public:int m_b;int m_c;
};
B::B(int b, int c): m_b(b), m_c(c){ }
//派生类C
class C: public A, public B{
public:C(int a, int b, int c, int d);
public:void display();public:int m_a;int m_c;int m_d;
};
C::C(int a, int b, int c, int d): A(a, b), B(b, c), m_a(a), m_c(c), m_d(d){ }
void C::display(){printf("A::m_a=%d, A::m_b=%d\n", A::m_a, A::m_b);printf("B::m_b=%d, B::m_c=%d\n", B::m_b, B::m_c);printf("C::m_a=%d, C::m_c=%d, C::m_d=%d\n", C::m_a, C::m_c, m_d);
}
int main(){C obj_c(10, 20, 30, 40);obj_c.display();cout<<"&obj_c.A::m_a="<<&obj_c.A::m_a<< " &obj_c.A::m_b="<<&obj_c.A::m_b<<"\n";cout<< "&obj_c.B::m_b="<<&obj_c.B::m_b<<" &obj_c.B:m_c="<<&obj_c.B::m_c<<"\n";//cout<<"&obj_c.C::m_a="<<&obj_c.C::m_a<<" &obj_c.m_c="<<&obj_c.C::m_c<<" &obj_c.C::m_d="<<&obj_c.C::m_d<<" &obj_c="<<&obj_c<<endl;cout<<"&obj_c.m_a="<<&obj_c.m_a<<" &obj_c.m_c="<<&obj_c.m_c<<" &obj_c.m_d="<<&obj_c.m_d<<" &obj_c="<<&obj_c<<endl;return 0;
}
A::m_a=10, A::m_b=20
B::m_b=20, B::m_c=30
C::m_a=10, C::m_c=30, C::m_d=40
&obj_c.A::m_a=0x7ffe5583e970 &obj_c.A::m_b=0x7ffe5583e974
&obj_c.B::m_b=0x7ffe5583e978 &obj_c.B:m_c=0x7ffe5583e97c
&obj_c.m_a=0x7ffe5583e980 &obj_c.m_c=0x7ffe5583e984 &obj_c.m_d=0x7ffe5583e988 &obj_c=0x7ffe5583e970
A、B 是基类,C 是派生类,假设 obj_c 的起始地址是 0X1000,那么 obj_c 的内存分布如下图所示:
基类对象的排列顺序和继承时声明的顺序相同。
C++多继承时的对象内存模型相关推荐
- C++继承时的对象内存位置(一)有成员变量遮蔽时的内存分布
#include <cstdio> #include<iostream> using namespace std; //基类A class A{public:A(int a, ...
- C++继承时的对象内存位置(一)
#include <cstdio> #include<iostream> using namespace std; //基类A class A{public:A(int a, ...
- C++对象模型4——多重继承的对象内存模型、vptr与vtbl的创建与重置的时机、不要在含有虚函数的类的构造函数中调用memset
一.多重继承的对象内存模型 class Base1 { public:virtual void f() {cout << "base1::f()" << e ...
- python对象内存模型
原文:Python的垃圾回收机制(二)之内存模型 1. Python对象内存模型 首先介绍一下Python对象的内存模型,如下图1所示: 图1. PyObject对象内存模型 上图可以看到,一个PyO ...
- Swift 对象内存模型探究(一)
MemoryLayout 基本使用方法 HandyJSON 是 Swift 处理 JSON 数据的开源库之一,类似 JOSNModel,它可以直接将 JSON 数据转化为类实例在代码中使用. 由于 S ...
- C++对象内存模型学习
本文原文出处为MSDN.如果你安装了MSDN,可以搜索到C++ Under the Hood.否则也可在网站上找到http://msdn.microsoft.com/archive/default.a ...
- java对象内存模型_Java对象的内存模型
众所周知,函数调用在内存中是通过压栈,退栈实现的,而Java的方法调用则是在JVM栈中通过栈帧实现的,且所有的Java对象都只在堆上分配内存.那么一个Java对象在堆内存里到底长啥样呢?实际上,当一个 ...
- C++独孤九剑第一式——拨云见日(对象内存模型)
归妹趋无妄,无妄趋同人,同人趋大有.甲转丙,丙转庚,庚转癸.子丑之交,辰巳之交,午未之交.风雷是一变,山泽是一变,水火是一变.乾坤相激,震兑相激,离巽相激······好了,要背心法的同学请课后自行背诵 ...
- C++虚继承下的内存模型(二)
对于虚继承,恰恰和普通继承相反,大部分编译器会把基类成员变量放在派生类成员变量的后面,这样随着继承层级的增加,基类成员变量的偏移就会改变,就得通过其他方案来计算偏移量. 下面我们来一步一步地分析虚继承 ...
最新文章
- 张贤国:视频压缩还远没有达到最优
- 用前考虑清楚,伤敌一千自损八百的字体反爬虫
- java 预览office_java在线预览office
- 《Java 8 in Action》Chapter 12:新的日期和时间API
- 42岁失业,有150万存款,房子无贷款,不想上班做点什么好?
- 用超 7500 万的 GitHub 代码仓库实力解读:哪门编程语言热度最高?
- 爱国者MID产品介绍
- 二分查找向上还是向下取整_113、股市中的跳空缺口判断技巧是向上还是向下
- 拓端tecdat|【视频】R语言生存分析原理与晚期肺癌患者分析案例|数据分享
- zookeeper 可以干什么
- java基本语法大全(全)_Java基本语法大全(全)
- 12帧跑步动画分解图_跑步动画原理讲解
- leetcode-排列组合问题
- 正在存储windows支持软件_ibm/lenovoDS3500扩展柜存储管理软件-北京瑞腾世纪科技有限公司...
- 图文详解 | 万用表的使用与口诀!十足干货,不要错过!
- 求解N的N次方的个位数
- swagger 接口参数顺序_swagger扩展为按代码定义顺序展示接口和字段
- 时间子系统10_hpet时钟初始化
- MATLAB2016笔记(九):概率统计( 概率密度、统计作图、统计特征、累积概率分布、随机变量产生)
- 基于 ocr 的屏幕文字识别 开源