首先来说如果结构体的内存是按照便捷对齐的话,比如下图的这个结构体:
假如按照边界对齐要求的话,恐怕需要24个字节的存储空间。而short类型和charl类型却仅仅占了不到一个double八个字节的空间。
本文探讨了C语言中结构体内存分配的问题,尤其是边界对齐导致的空间浪费现象。通过对不同结构体布局的实验,揭示了结构体成员的内存位置与其偏移量的关系,以及如何依据最大类型进行内存对齐。实验结果显示,结构体的起始位置总是4或8的倍数,并且成员之间的填充遵循一定的对齐规则。

被折叠的 条评论
为什么被折叠?
