结构体内存对齐的简单讲解

博客讨论了C语言中结构体内存对齐导致的大小计算问题。内存对齐基于平台和性能考虑,确保数据在特定地址边界对齐,减少访问次数。结构体的大小会根据成员对齐规则进行调整,即使成员总字节数小于实际结构体大小。内存对齐是牺牲空间来换取更快的存取速度。
摘要由CSDN通过智能技术生成

 这里结构体里有三个成员,一个是一个字节的c1,一个是四个字节的i,一个是一个字节的c2,但是这里sizeof算出来的确实十二个字节,这是为什么呢?

 

1.我们将内存假设是竖着排放的,结构体内的第一个成员

——是放在结构体变量在内存中存储位置0的偏移处开始的

2.从第二个成员往后的所有成员,都放在一个对齐数(成员的大小和默认对齐数的较小值)的整数的整数倍的地址处。

3.结构体的总大小是结构体的所有成员的对齐数中最大对齐数的整数倍。

那么为什么会存在内存对齐呢?

 大部分的资料都是如是说的:

1.平台原因(移植原因):不是所有的硬件平台都能访问任意地址上的任意数据的;某些硬件平台只能在某些地址处取某些特定类型的数据,否则抛出硬件异常。

2.性能原因:数据结构(尤其是栈)应该尽可能地在自然边界上对齐。原因在于,为了访问未对齐的内存,处理器需要做两次内存访问;二对齐的内存访问仅需要一次访问。

总的来说:

        结构体的内存对齐是拿空间换取时间的做法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值