sizeof(class)情况
Q1:定义一个空的类型,里面没有任何成员变量和成员函数。对该类型求sizeof,得到的结果是?
答案为 1,不是0
原因:空类型的实例中不包含任何信息,本来sizeof应该为0,但是当我们声明该类型时,它必须在内存中占有一定空间,否则将无法使用这些实例。至于占多少内存,由编译器决定。
minGW、vs中均是 1
例子:
#include <iostream>
using namespace std;
class CExample
{
};
int main(void)
{
CExample a ;
cout << "the size of a null class is : " << sizeof(a) << endl;
return 0;
}
输出结果:the size of a null class: 1
Q2:如果在该类型中添加一个构造函数和析构函数,再对该类型求sizeof,得到的结果?
答案依然为1。
原因: 调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址只与类型相关,与类型的实例无关,编译器也不会因为这两个函数而在实例内添加任何额外的信息。
Q3: 如果把析构函数标记为虚函数,结果又会如何?
答案:若编译器若为32位则为4,若编译器为64位则为8
原因:C++编译器一旦发现一个类型中有虚函数,则会为该类型生成虚数表,并在该类型的每一个实例 添加一个虚数表的指针,因为若32位 则为4,若64为,则为8