如何实现C语言中结构体的动态内存分配?
- 内容介绍
- 文章标签
- 相关推荐
本文共计625个文字,预计阅读时间需要3分钟。
一、结构体内存分配原则原则一:结构体中元素按定义顺序存储到内存中,但并非紧密排列。
从结构体存储的首地址开始,每个元素依次存储到内存中,每个元素都会被视为内存的一部分。
一、结构体内存分配原则-
原则一:结构体中元素按照定义顺序存放到内存中,但并不是紧密排列。从结构体存储的首地址开始 ,每一个元素存入内存中时,它都会认为内存是以自己的宽度来划分空间的,因此元素存放的位置一定会在自己大小的整数倍上开始。
-
原则二: 在原则一的基础上,检查计算出的存储单元是否为所有元素中最宽的元素长度的整数倍。若是,则结束;否则,将其补齐为它的整数倍。
注意:如果有充分的理由决定不对结构的成员进行重排,以减少因对齐带来的空间损失。列如,为了提高程序的可维护性和可读性,将相关的结构成员存储在一起。应该根据结构成员的边界需要进行重排,减少因边界对齐而造成的内存损失。
- sizeof操作能够得出一个结构的整体长度,包括因边界对齐而跳过的那些字节。
本文共计625个文字,预计阅读时间需要3分钟。
一、结构体内存分配原则原则一:结构体中元素按定义顺序存储到内存中,但并非紧密排列。
从结构体存储的首地址开始,每个元素依次存储到内存中,每个元素都会被视为内存的一部分。
一、结构体内存分配原则-
原则一:结构体中元素按照定义顺序存放到内存中,但并不是紧密排列。从结构体存储的首地址开始 ,每一个元素存入内存中时,它都会认为内存是以自己的宽度来划分空间的,因此元素存放的位置一定会在自己大小的整数倍上开始。
-
原则二: 在原则一的基础上,检查计算出的存储单元是否为所有元素中最宽的元素长度的整数倍。若是,则结束;否则,将其补齐为它的整数倍。
注意:如果有充分的理由决定不对结构的成员进行重排,以减少因对齐带来的空间损失。列如,为了提高程序的可维护性和可读性,将相关的结构成员存储在一起。应该根据结构成员的边界需要进行重排,减少因边界对齐而造成的内存损失。
- sizeof操作能够得出一个结构的整体长度,包括因边界对齐而跳过的那些字节。

