c语言中结构体占用内存分析

在说结构体之前有必要先说一下在不同编译器中各变量所占内存字节大小:

      1、32位编译器下,即X86环境下

       

指针类型都是占用4个字节,如char* 、int*、double*

2、对于64位系统即X64环境,64位编译器下:


指针类型都是占用4个字节,如char* 、int*、double*

从而可以看出在32位和64位编译器中,除了指针变量的寻址范围从32位增加到了64位,其他变量占用字节数是一样的。但对于16位系统int变量只有两个字节,要单独来分析。

现在可以说一下结构体占用空间的问题了(32位编译器)。

struct TEST1
{
	char a;
	short b;
	int c;

}t1;
这个结构体中,sizeof(t1)为8,因为最大字节数变量int是4字节,这里是默认4字节对齐的

怎么理解上段绕口的定义呢?可以有以下几个例子解释。

1、

#include<stdio.h>
#pragma pack(push) //保存对齐状态
#pragma pack(4)
struct TEST1
{	
	int a;
	double b;
	short c;
}t1;
int main()
{
	printf("%d",sizeof(t1));

return 0;
}
其中 int、double、short一共是4+8+2=14,大于定义的4字节数对齐方式,所以可以不用满足默认对齐方式,必须满足4字节数对齐,所以sizeof(t1)结果为16字节,


那么问题来了,什么是默认对齐方式呢?

可以这样简单解释一下,

#pragma pack(4)
struct TEST1
{	
	char a;
}t1;
这个结构体中char字节数为1小于设置的4字节数对齐,所以要满足默认字节数对齐,故sizeof(t1)结果是1,而不是4.

还有一种可能就是,

#include<stdio.h>
//#pragma pack(push) //保存对齐状态
//#pragma pack(4)
struct TEST1
{	
	int a;
	double b;
	short c;
}t1;
int main()
{
	printf("%d",sizeof(t1));

return 0;
}
这个程序的结果为24,因为没有指定字节数对齐方式,故采用默认的对齐方式8字节对齐(double类型字节数为8).


再来看下一个例子:

#include<stdio.h>
//#pragma pack(push) //保存对齐状态
//#pragma pack(4)
struct TEST1
{	
	char a;
	short b;
	double c;
	
}t1;
int main()
{
	printf("%d",sizeof(t1));

return 0;
}
发现这个程序和上个有什么区别没有?只是调换了一下double和short的顺序而已,那结果如何呢?

显然sizeof(t1)结果为16,空间分配如下图:


当然了,如果设置对齐方式为4字节对齐,结果又不一样了。

#include<stdio.h>
#pragma pack(4)
struct TEST1
{	
	char a;
	short b;
	double c;
	
}t1;
int main()
{
	printf("%d",sizeof(t1));

return 0;
}
这段程序的结果为12,空间分配如下图:

洋洋洒洒写了这么多,可能有点乱,最近很多校招,有时间再改。



   

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言,计算一个结构体占用多大的内存可以根据以下规则进行计算。首先,结构体的大小是其成员变量所占内存大小的总和,但是要注意对齐规则。结构体内存对齐的基本原则是,结构体的起始地址要对齐到其最宽的成员变量的大小的倍数。也就是说,结构体的起始地址要能够同时满足所有成员变量的对齐要求。 例如,如果有一个结构体`struct example`,其包含了不同类型的成员变量,比如`int`、`char`和`double`,那么根据对齐规则,编译器会在不同类型的成员变量之间插入一些空白字节,以满足对齐要求。 具体的对齐规则可能因编译器和操作系统的不同而有所差异,但通常情况下,对齐要求是按照成员变量的大小来确定的。比如,`char`类型一般对齐要求为1字节,`int`类型一般对齐要求为4字节,`double`类型一般对齐要求为8字节。 因此,计算结构体内存大小时,需要按照对齐规则,将每个成员变量的大小上取整到其对齐要求的倍数,然后将这些大小相加。最后得到的结果就是结构体的大小。 需要注意的是,在某些情况下,可以通过使用`#pragma pack`指令来改变对齐规则。比如,`#pragma pack(4)`可以将对齐要求设置为4字节。但是在嵌入式开发,为了节约内存使用,可能需要手动设置对齐规则。 总结起来,计算C语言结构体内存大小,可以按照以下步骤进行: 1. 根据对齐规则,确定每个成员变量的对齐要求。 2. 将每个成员变量的大小上取整到其对齐要求的倍数。 3. 将这些大小相加,得到结构体的大小。 参考资料: C语言学习笔记-结构体占用内存大小的计算 结构体内存对其计算结构体大小 C语言数据类型占内存大小

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值