第一种情况:一个空类
class A {};
其类型大小是sizeof(A)等于1,即占有一个字节。原因是因为每个对象必须必须在内存中配置独一无二的地址,因此编译器默认为该类提供了一个char类型的数据成员,使该空类的大小为1byte。
第二种情况:有一个派生类的情况,且派生类也是空类
class A {};
class B : public A {};
由于编译器的优化,sizeof(B)大小也是1byte
第三种情况:基类有数据成员
class A
{
int x;
};
class B : public A {};
现在 sizeof(A)的大小是4bytes(32位机器上,以下相同),sizeof(B)的大小也是4bytes,因为它含有从基类继承过来的数据成员。
第四种情况:基类有虚函