空类的sizeof,有一个虚函数的类的sizeof

今天面试,忽然被问到这个题目,查了一下果然有欸。

#include <iostream>
using namespace std;
class A
{
};

class B
{
public:
    B() {}
    ~B() {}
};

class C
{
public:
    C() {}
    virtual ~C() {}
};

int main(int argc, _TCHAR* argv[])
{
    cout<<sizeof(A)<<"\t"<<sizeof(B)<<"\t"<<sizeof(C)<<endl;
    return 0;
}

看看运行结果:

注意,我的是64位机。

再看看网上人家的解释:

class A是一个空类型,它的实例不包含任何信息,本来求sizeof应该是0。但当我们声明该类型的实例的时候,它必须在内存中占有一定的空间,否则无法使用这些实例。至于占用多少内存,由编译器决定。Visual Studio 2008中每个空类型的实例占用一个byte的空间。
 
class B在class A的基础上添加了构造函数和析构函数。由于构造函数和析构函数的调用与类型的实例无关(调用它们只需要知道函数地址即可),在它的实例中不需要增加任何信息。所以sizeof(B)和sizeof(A)一样,在Visual Studio 2008中都是1。
 
class C在class B的基础上把析构函数标注为虚函数。C++的编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每一个实例中添加一个指向虚函数表的指针。在32位的机器上,一个指针占4个字节的空间,因此sizeof(C)是4。

 当然,最后的class C看你的机器字长喽。

 

posted on 2017-09-21 19:56  枝桠  阅读(786)  评论(0编辑  收藏  举报

导航