结构体的大小?
看到下面两个例子,你可能就发现结构体他和我们一般的变量大小是不同的,这里存在内存对其,最小单位问题;
首先我们先明白内存对其是什么鬼,看到下图相信你就明白什么是内存对齐了,在这块的话有很多种排列画法,为什么我们要选择下面这种画法呢?因为我们定义的结构体变量有先后顺序,在编译时,会根据我们的代码由上到下去规划开辟内存并且一端对其,这样更能有效的运行,虽然浪费一些内存。那么一行放几个字节就是我们所要说得最小单位,这里的最小单位是根据我们的程序定的,比如在下图,就根据int占4个字节去排列,然后在考虑顺序的前提下内存高校利用,就有了如下的排列方式。一般再没有指定最小单元是多少的情况下,都是按照如下规则:
由于存储变量时地址对齐的要求,编译器在编译程序时会遵循两条原则:
一、结构体变量中成员的偏移量必须是成员大小的整数倍(被认为是任何数的整数倍)
二、结构体大小必须是所有成员大小的整数倍。
由于在没有指定最小单元的情况下内存可能会存在很多浪费,我们就引入如下的概念:指定对齐值函数为
#pragma pack (value)时的指定对齐值value
如下是规则和代码:
这是一个问题,有悖我们的规则,那么这其中有什么奥秘有待我们解决 ?
484

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



