空类大小为1字节,因C++标准要求同一类型对象地址必须唯一;含成员类大小由成员总和、内存对齐填充及虚表指针决定;继承时遵循空基类优化、虚继承加vbptr等规则。

因为 C++ 标准规定:同一个类型的两个对象在内存中不能拥有相同的地址。如果空类 class A {}; 的大小为 0,那么声明 A a, b; 时,a 和 b 就可能被分配到同一地址,违反对象唯一性要求。编译器必须至少分配 1 字节来保证每个对象有独立地址。
这个 1 字节不存储任何用户数据,也不可访问(没有成员变量),纯粹是“占位符”——你可以用 sizeof(A) 验证结果恒为 1,无论是否含默认构造/析构函数。
类的大小由三部分决定:所有非静态成员变量的大小总和、内存对齐填充、以及可能的虚函数表指针(vptr)。
sizeof 值alignof 值)调整偏移量,插入必要填充字节alignof(类名)),末尾可能补填充vptr(通常 8 字节 on x64),并影响整体对齐例如:struct S { char a; int b; }; 在 x64 下,a 占 1 字节,但 b 要求 4 字节对齐,所以中间填 3 字节;sizeof(S) 是 8,不是 5。
派生类大小 = 基类部分大小 + 派生类新增成员大小 + 可能的额外填充,但要注意:
class B {};),且不是虚继承,编译器可完全省略其空间占用——sizeof(derived) 可能等于仅新增成员的大小例如:struct D : B { int x; };(B 为空),sizeof(D) 很可能是 4(而非 1+4),这就是 EBO 在起作用。
实际计算时,别只盯着成员变量列表,这几个点常导致预估偏差:
#pragma pack 或 alignas 会显式改变对齐,直接破坏默认填充逻辑sizeof,它们存在全局区,与对象实例无关sizeof 不跨平台保证一致最稳妥的方式永远是实测:static_assert(sizeof(MyClass) == N);,而不是靠手算推导——尤其在涉及模板、多重虚继承或自定义对齐时,手动计算极易出错。