你是否有观察过结构体中数据变量所占的字节数,以及结构体所占的字节数?
如:
图1 图2 图三
你是否知道图1,2,3中结构体所占的字节数么?
在此之前,我们需要知道在32位操作系统上,int 占 4字节,char 占 1 字节,因此你可能会说,图一结构体占有2 字节,图二结构体占有 3 字节,图三结构体占 1+1+1+4+1=8字节,如果是这样,可能你没有了解到 一种 说法 “字节对齐”
所谓 字节对齐 是指 以使 CPU 存储速度更快,提高性能 为目的,对 结构体 内部排列 做的一种 调整。
偏移量 是指 一种 数据类型 以当前 地址为基准,向高地址 走 sizeof(数据类型)个 字节数,到达下一个数据类型的所在地址。
在一般情况下:
char 型 偏移量 为sizeof(char)即 1 的 倍数, short 型 偏移量 为sizeof(short)即 2 的 倍数
int 型 偏移量 为sizeof(int)即 4 的 倍数,float 型 偏移量 为 sizeof(float)即 4 的 倍数
double 型偏移量 为 sizeof(double)即 8 的 倍数
因此在 一般情况下:图一为 2 字节,图二 为 3 字节,图三 为 12 字节。具体看下方示意图:
但在特殊情况下也可以改变 字节对齐的方式
如:使用 #pragmapack(n) 可以改变 以 n 字节对齐, 具体请 参考 (https://baike.sogou.com/v69320136.htm)