您的位置:首页 > 编程语言 > C语言/C++

C++对象模型(1):对象内存布局简介

2013-02-04 11:45 381 查看
我们知道当实例化一个类时,也就是产生一个对象时需要分配内存空间.那一个对象具体需要多少字节的内存空间? 通过些什么规则计算出来的?

假如有如下一个类

------------------------------------------------------------------------------------------------------------------------------

类声明Arwen.h

class Arwen

{

public:

Arwen(void);

virtual ~Arwen(void);

int Age();

staticvoid
Height(int);

private:

int m_nAge;

staticint
s_nHeight;

};

----------------------------------------------------------------------------------------------------------------------------------

类源文件Arwen.cpp

#include "Arwen.h"

int Arwen::s_nHeight = 1; //记得初始化静态变量

Arwen::Arwen(void){ }

Arwen::~Arwen(void){ }

int Arwen::Age ()

{

return m_nAge;

}

void Arwen::Height(int
a)

{

s_nHeight = a;

}

-----------------------------------------------------------------------------------------------------------------------

假如实例化上面这样一个类,在内存中是怎么样分配空间的呢?

我们知道一个类包括成数据成员(data members)和成员函数(member functions).

数据成员分为static 和 nonstatic

成员函数分为static , nonstatic, virtual

数据成员内存分配

static变量是在静态存储区(有人也叫数据段)分配空间.而nonstatic变量则在对象中分配空间.

所以static
int s_nHeight;是在静态存储区分配空间,不在对象空间的计算之内.int m_nAge;就需要4字节空间

成员函数内存分配

static和nonstatic成员函数都是在代码区(或者叫文本段)中分配内存.也不在对象内容的计算之内.

virtual成员函数(不管多少个),都只都只会在对象中插入一个指针,指向一个virtual table(这是保存在哪个地方?还没搞懂),virtual table里面保存着一堆指针,一个指针是指向类型信息,其他的都指向虚函数的地址.虚函数本身跟static和nonstatic成员函数一样是保存在代码区.

由于类Arwen中有虚函数,所有编译器会自动插入一个指针指向virtual table,指针在32位系统上是4位.

所以实例化类Arwen需要分配8字节的内存空间.int m_nAge的4字节,加上指向虚表的指针4字节.

你可以用sizeof(Arwen)计算下就会发现结果是8.

不过其实有时一些特殊情况会结果未必就是这样计算出来的值.例如一个类没有任何数据成员和虚成员函数,理就为0,但sizeof发现会是1,这是因为在内存中好歹要用点啥来唯一标志一个类.另外有时计算出来的值是7或其他啥不是2的整数倍,由于有个啥内存对象的机制(可能又会按成员数据对齐,整体对齐),最终sizeof的结果可能不太一样.

内存对齐详见:http://baike.baidu.com/view/4786260.htm
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: