C++中sizeof问题

1、对于类和对象

Class A; A obj;

sizeof(A)==sizeof(obj)

一个类中,虚函数、成员函数(包括静态与非静态)和静态数据成员都是不占用类对象的存储空间的。
对象大小= 虚函数表指针(4个字节) + 所有非静态数据成员大小 + 对齐字节大小
注意:

  • 如果没有定义虚函数,则不用计算虚函数表指针
  • 对齐字节大小符合规律:
    • 结构体变量的首地址能够被其最宽基本类型成员的大小所整除,基本类型是指char、short、int、float、double这样的内置数据类型;
    • 结构体每个成员相对于结构体首地址的偏移量(offset)都是成员大小的整数倍,如有需要编译器会在成员之间加上填充字节(internal adding)
    • 结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要编译器会在最末一个成员之后加上填充字节(trailing padding)。
    • 如果结构体的成员是复合类型(如结构体),那么计算最宽基本类型时,是看复合类型的成员,而不是将复合类型看成一个整体。

2、对于空类,sizeof大小为1
空类同样可以被实例化,每个实例在内存中都有一个独一无二的地址,为了达到这个目的,编译器往往会给一个空类隐含的加一个字节,这样空类在实例化后在内存得到了独一无二的地址.
3、当sizeof的参数是数组名时,计算的是整个数组的存储大小;当sizeof的参数是指针时,计算的是指针的大小(8字节,64位系统)。

参考链接:https://blog.csdn.net/muzilanlan/article/details/27075619

发布了75 篇原创文章 · 获赞 12 · 访问量 7万+

猜你喜欢

转载自blog.csdn.net/qq_20817327/article/details/104945786