【剑指offer】C++中sizeof(空类)问题总结

剑指offer-22~23

问题描述:

  • 定义一个空的类型,里面没有任何成员变量和成员函数。对该类型求sizeof,得到的结果时多少?
  • 在该类中添加构造函数和析构函数,再对该类型求sizeof,得到的结果时多少?
  • 如果析构函数标记为虚函数呢?再对该类型求sizeof,得到的结果时多少?

代码测试:

#include <iostream>
using namespace std;
//空类
class classA{};
//包含构造函数和析构函数
class classB
{
    classB(){};
    ~classB(){};
};
//包含4B的成员变量
class classC
{
private:
    int a;
};
class classD
{
private:
    int a;
    void Print()
    {
        cout << a << endl;
    }
};
//包含虚函数的析构函数
class classE
{
    int a;
    void Print()
    {
        cout << "hello world" << endl;
    }
    virtual ~classE(){};
};
int main()
{
    cout << sizeof(classA) << "  ";
    cout << sizeof(classB) << "  ";
    cout << sizeof(classC) << "  ";
    cout << sizeof(classD) << "  ";
    cout << sizeof(classE) << "  ";
    getchar();
    return 0;
}

vs2013+windows7
64位:指针和int均占8个字节


Paste_Image.png

32位:指针和int均占4个字节


结果分析:

  • 定义一个空的类型,里面没有任何成员变量和成员函数。对该类型求sizeof,得到的结果时多少?
    空类型的实例不包括任何信息,本来求sizeof应该是0,但是我们在声明该类型实例的时候,必须给实例在内存中分配一定的空间,否则无法使用该实例。由于空类型不含任何信息,故而所占的内存大小由编译器决定。codeblocks和Visual Studio中每个空类型的实例占1Byte。切忌:一旦类中有其他的占用空间成员,则这1个字节就不在计算之内。参考classA
  • 在该类中添加构造函数和析构函数,再对该类型求sizeof,得到的结果时多少?
    ** 仍然为1Byte。调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址只与类型相关,而与类型的实例不相关。如果有其他成员函数(非虚函数),则还是只占用1个字节。参考classB和classC和classD**
  • 如果析构函数标记为虚函数呢?再对该类型求sizeof,得到的结果时多少?
    **C++编译器一旦发现类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每个实例中添加一个指向虚函数表的指针。在32位的机器上,一个指针占4B;在64位的机器上,一个指针占8B。参考classE **

推荐阅读更多精彩内容