美文网首页
【待更新】C++中sizeof的理解

【待更新】C++中sizeof的理解

作者: 成江海 | 来源:发表于2017-04-02 17:16 被阅读0次

重新回顾C++基础知识,发现很多有趣的事情。

1、普通数据类型的sizeof

普通数据类型,比如说char、short、int、long、ptr等等,和系统位数(32位或者64位)有关。

2、数组的sizeof

3、结构体的sizeof

4、类的sizeof

4.1 空类

仅有类的声明,没有任何成员函数,也没有任何成员数据。这种类的sizeof固定为1。

以上代码运行后输出结果为:A=1, a=1

空类也是类,也可以进行实例化,在编译空类的时候编译器会隐含添加1个字节,以便实例化的时候不同的对象拥有不同的地址(To ensure that the addresses of two different objects will be different.),所以空类的sizeof为1。

返回的结果为:A=1, a=1

类的大小与它的构造函数、析构函数(虚析构函数除外)和其他普通函数成员(虚函数除外)无关,只已它的数据成员有关。

4.2 普通类

普通的类中,包含普通的函数或者数据成员。

4.2.1 普通函数成员和普通数据成员

返回的结果为:A=8, a=8, size=8

4.2.2 多个不同数据类型的数据成员,如下定义:

返回的结果为:A=16, a=16, size=16

返回的结果为:A=32, a=32, size=22

我们将数据成员变量p和z的声明的位置互换,看下面这个例子:

返回的结果为:A=24, a=24, size=22

为什么sizeof的结果不一样呢?原因是这里面存在字节对齐问题。

4.2.3 有静态数据成员

返回结果为:A=8, a=8, size=8

静态数据成员被编译器放在程序的一个global data members中,它是类的一个数据成员。但是它不影响类的大小,不管这个类实际产生了多少实例,还是派生了多少新的类,静态数据成员在类中永远只有一个实体存在。而类的非静态数据成员只有被实例化的时候,他们才会被创建。但是类的静态数据成员一旦被声明,无论类是否被实例化,它都已被创建。可以这么说,类的静态数据成员是一种特殊的全局变量。

4.2.4 有虚函数

包含虚函数的类

返回的结果为:A=8, a=8

当类中有虚函数(包括虚析构函数)的时候,会有一个指向虚函数表的指针(vptr),在32位系统分配指针大小为4字节,64位系统分配指针大小为8字节。

4.3 有继承

4.3.1 简单继承关系

4.3.2 有虚函数继承关系

4.3.3 虚继承关系

当存在虚拟继承时,派生类中会有一个指向虚基类表的指针。所以其大小应为普通继承的大小,再加上虚基类表的指针大小。

相关文章

网友评论

      本文标题:【待更新】C++中sizeof的理解

      本文链接:https://www.haomeiwen.com/subject/zfopkttx.html