结构体内存对齐(看不懂你打我^^

本文详细介绍了结构体内存对齐的概念及其原因,并通过实例解释了内存对齐的规则。文章还提供了调整默认对齐数的方法,以实现内存的高效利用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为了计算结构体所占内存大小,引入结构体内存对齐这一概念。

为什么要引入内存对齐呢?

Above all,结构体的内存对齐是拿空间来换取时间的做法!!!
 

 在计算结构体大小之前,首先了解一下内存对齐的规则:

1. 第一个成员在与结构体变量偏移量为0的地址处。
2.其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。

3.对齐数 = 编译器默认的一个对齐数 与 该成员大小的较小值。(vs中默认对齐数为8,linux环境中无默认对齐数)

4.如果嵌套了结构体的情况,嵌套的结构体对齐到自己的最大对齐数的整数倍处,结构体的整
体大小就是所有最大对齐数(含嵌套结构体的对齐数)的整数倍。

具体引例:(以下测试环境均为vs2019,默认对齐数为8

【1】

struct S3
{
	double d; //自身大小为8字节,默认对齐数为8,其对齐数为8,
	char c;//自身大小为1字节,默认对齐数为8,其对齐数为1,
	int i; //自身大小为4字节,默认对齐数为8,其对齐数为4,
};  //sizeof(struct S3)==16

 

【2】

struct S4   //结构体嵌套
{
	char c1;   //自身字节数为1,默认对齐数为8,1<8,则其对齐数为1
	struct S3 s3;//嵌套结构体,那么嵌套的结构体要对齐到其最大对齐数的整数倍处,即8的整数倍,因为S3中最大对齐数为8
	double d;   //自身字节数为8,默认对齐数为8,8==8,则其对齐数为8
	         //整体结构体大小要对齐到 “ 结构体内所有数据所对应的对齐数 ” 中的 “ 最大对齐数的整数倍 ”处
};    // sizeof(struct S4)==32

 

 

 

那在设计结构体的时候,我们既要满足对齐,又要节省空间,如何做到:
 

Abstract:让占用空间小的成员尽量集中在一起,以填满内存中犄角旮旯的区域,不至于浪费过多内存空间。

这里先看一个引例:

struct S1
{
char c1;
int i;
char c2;
};     //sizeof(struct s1)==12
struct S2
{
char c1;
char c2;
int i;
};     //sizeof(struct s2)==8

S1和S2类型的成员一模一样,但是S1和S2所占空间的大小有了一些区别。

这也就是为什么要把占用空间小的成员尽量集中在一起的原因。

结构在对齐方式不合适的时候,我们可以自己更改默认对齐数。

目的:也是为了使得内存得以更高效使用,节省浪费的空间。

      ----用到#pragma 这个预处理指令

 使用用例:

--设置字节对齐方式为2字节对齐:

#pragma pack(2)//设置默认对齐数为2
struct S2
{
    char c1;
    int i;
    char c2;
};
#pragma pack()//取消设置的默认对齐数,还原为默认
int main()
{
    //输出的结果是什么?
    printf("%d\n", sizeof(struct S2));  //结果为8
    return 0;
}

制作不易,希望小主们能观有所获,也希望uu们能不吝3连呀!!!

带家妻在此谢过大家了 !(狗头保命^^

 

评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

T7ooo3o

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值