sizeof运算符返回对象或类型在内存中的字节大小,但其结果受多种因素影响。1. sizeof是编译期运算符,无法反映运行时实际内存使用情况。2. 类对象的大小受成员变量顺序、填充(padding)和对齐(alignment)影响,通常不等于成员变量大小之和。3. 若类包含虚函数,则对象会包含虚函数表指针(vptr),增加对象大小(通常为4或8字节)。4. sizeof不计算动态分配的堆内存,仅计算栈上对象本身的大小,如指针大小而不包括其所指数据。掌握这些行为有助于正确理解c++++对象模型并避免内存误判问题。

C++中,sizeof运算符常被用来测量对象或类型的内存占用。但很多人对它的理解仅停留在“返回类型或变量的大小”这个表面认知上,而忽略了它的一些细节和限制。这篇文章将从实际出发,解析sizeof在不同场景下的行为,以及它在测量C++对象内存占用时的适用范围。

sizeof的基本用法与常见误解sizeof可以用于类型或变量,返回其在内存中所占的字节数。例如:
int a; std::cout << sizeof(a); // 输出4(在大多数32位系统下)
需要注意的是,sizeof是一个编译期运算符,也就是说它的结果在编译阶段就已经确定,并不会真正运行代码去“计算”对象的大小。
立即学习“C++免费学习笔记(深入)”;

常见误区:
sizeof能反映对象运行时的实际内存使用情况。当你用sizeof测量一个类的对象时,结果往往不是所有成员变量大小的简单相加。这是因为编译器会根据目标平台的内存对齐规则插入填充字节(padding),以提升访问效率。

举个例子:
struct Example {
char c; // 1字节
int i; // 4字节
};在很多平台上,sizeof(Example)的结果是8,而不是5。这是因为在char后面插入了3个字节的填充,使得int能按4字节对齐。
几点关键点:
#pragma pack)手动调整对齐方式,但这通常不推荐,除非有特殊需求。如果类中包含虚函数,那么该类的对象会有一个指向虚函数表的指针(vptr)。这个指针通常占用4或8字节(取决于32位或64位系统),并会被计入sizeof的结果中。
例如:
class Base {
public:
virtual void foo() {}
};
std::cout << sizeof(Base); // 在64位系统上输出8即使类没有任何成员变量,只要存在虚函数,对象也会因vptr的存在而占用一定空间。
注意:
sizeof里sizeof只能告诉你栈上对象本身的大小,对于那些在堆上分配的资源(比如指针指向的内容)是无能为力的。
例如:
struct Data {
int* arr;
};
Data d;
d.arr = new int[100]; // 占用了400字节(假设int为4字节)
std::cout << sizeof(d); // 输出通常是8(指针大小)+ padding,而不是408这时候,sizeof只计算了指针本身的空间,而不包括它指向的数据。如果你想知道整个结构的“深”内存占用,必须自己实现统计逻辑。
基本上就这些。掌握sizeof的行为不仅能帮助你更好地理解C++对象模型,还能避免一些常见的性能和内存管理问题。虽然看起来简单,但在实际开发中很容易忽略细节导致误判。
以上就是怎样测量C++对象的内存占用 sizeof运算符深入解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号