1. 测试代码
#include <bits/stdc++.h>
using namespace std;
class A{
public:
int a;
};
class B : virtual public A{
};
class C : virtual public A{
};
class D : public B, public C{
};
int main(int argc, char* argv[]){
A a; B b; C c; D d;
return 0;
2. g++ 编译
g++ test.cpp -o test -m32 -g
3. gdb 调试
首先启用 gdb 调试:
$ gdb test
然后在 return 0;
所在行打断点:
(gdb) b 20
Breakpoint 1 at 0x80486cc: file test.cpp, line 20.
运行到断点处:
(gdb) run
Starting program: /root/test
Breakpoint 1, main (argc=1, argv=0xffffd754) at test.cpp:20
20 return 0;
设置打印格式:
(gdb) set p pretty on
打印对象内存分布:
(gdb) p d
$1 = {
<B> = {
<A> = {
a = -10404
members of B:
_vptr.B = 0x80488ac <vtable for D+12>
<C> = {
members of C:
_vptr.C = 0x80488b8 <VTT for D>
}, <No data fields>}
可以看到,虚基类在子类中只有一份拷贝。
打印对象大小:
(gdb) p sizeof(d)
$2 = 12
Linux(ubuntu16.04) 下利用 gdb 查看 C++ 对象内存分布1. 安装 gdb (已安装请跳过)2. 利用 gdb 查看对象内存分布1. 安装 gdb (已安装请跳过)1. 安装 gdb$ sudo apt-get update$ sudo apt-get install gdb2. 添加 -m32 编译支持$ sudo apt-get install build-essential module-assistant $ sudo apt-get install gcc
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 前一段时间再次拜读《Inside the C++ Object Model》 深入探索C++对象模型,有了进一步的理解,因此我也写了四篇博文算是读书笔记:
Program Transformation Semantics (程序转换语义学)
面试中经常遇到类似多态,虚继承,RTTI,dynamic_cast实现原理之类的问题,这块需要对C++底层内存模型比较理解。C++由于没有存储对象元信息(java反射基础),要支持多态,多继承特性,导致C++对象内存模型异常复杂。
一. 继承内存模型
1. 基类
struct B
long b;
virtual void foo(){}