最推荐使用std::declval获取类成员变量大小,即sizeof(std::declval().member),该方法安全且适用于模板编程,不依赖实际对象或指针操作。

在C++中,不能直接获取类成员变量的大小,但可以通过一些技巧间接实现。标准C++没有提供类似 sizeof(member) 这样的语法来直接获取某个成员变量的大小,但我们可以通过以下几种方式来获取类成员变量的大小。
使用offsetof宏结合指针运算
利用标准库中的 offsetof 宏(定义在
但这方法不通用,尤其在有内存对齐或填充的情况下容易出错。
最可靠方法:使用sizeof直接作用于对象成员
最简单、最直接的方法是创建类的临时对象,然后使用 sizeof 获取成员变量的大小:
立即学习“C++免费学习笔记(深入)”;
struct MyClass {
int a;
double b;
char c;
};
// 获取成员变量大小
size_t size_a = sizeof(((MyClass)0)->a); // 合法,不会解引用空指针
size_t size_b = sizeof(((MyClass)0)->b);
size_t size_c = sizeof(((MyClass*)0)->c);
说明:
- ((MyClass*)0) 是一个指向地址0的指针,仅用于编译期计算,不会实际访问内存。
- sizeof 是编译期操作符,只依赖类型信息,不需要真实对象。
- 这种写法被广泛接受,常见于底层库和模板代码中。
使用std::declval(C++11及以上,更安全)
避免使用空指针,可采用 std::declval 来获得一个“假想”对象的引用:
#includesize_t size_a = sizeof(std::declval
().a);
优点:
- 不涉及空指针,语义更清晰。
- 在模板中尤其有用,适用于尚未构造类型的场景。
静态断言验证成员大小
可以在编译期做检查,确保成员大小符合预期:
static_assert(sizeof(std::declval().b) == 8, "double should be 8 bytes");
基本上就这些常用方法。推荐使用 sizeof(std::declval,它更现代、安全,适合泛型编程。虽然C++不直接支持“成员大小”查询,但通过类型表达式完全可以实现。关键是理解 sizeof 的编译期特性,以及如何合法构造成员访问表达式。











