C语言开发中内存分配的操作

来源:爱站网时间:2021-03-19编辑:网友分享
C语言是的目的是保存多个对象,而节省内存的资源这个操作一定是比较复杂的,今天爱站技术频道小编就为大家带来了C语言开发中内存分配的操作,希望能为你带来帮助。

C语言是的目的是保存多个对象,而节省内存的资源这个操作一定是比较复杂的,今天爱站技术频道小编就为大家带来了C语言开发中内存分配的操作,希望能为你带来帮助。

先说含有多个字段(field)的字(word)所占空间的规律——含有多个字段的字的大小是所有字段的类型中的最长的那个的倍数。但要确定究竟是最长类型的几倍则比较复杂,这要看是否需要考虑类型对齐问题(即一个字段能否跨越两个最长类型)。

例1:

struct word {
char  field1 : 1;
char  field2 : 2;
int     field3 : 4;
};

前两个字段都是char类型,第三个是int类型,所有类型中最长的是int类型。所以字的大小是int类型长度(即4字节)的倍数。而size of word的结果是4字节(即int的1倍),这是因为word的三个字段总共7位(1+2+4),小于int的32位,且不需 考虑类型对齐问题。

例2:

struct word {
char  field1 : 1;
char  field2 : 2;
int     field3 : 30;
};

与上例一样, 所有 类型中最长的是 int类型。所以字的大小是int类型长度(即4字节)的倍数。而size of word的结果是8字节(即int的2倍),这是因为word的三个字段总共33位(1+2+30),需要两个int的64位才能装下, 且不需 考虑类型对齐问题。

例3:

struct word {
char  field1 : 3;
char  field2 : 6;
char  field3 : 3;
};

所有 类型中最长的是 char类型。所以字的大小是char类型长度(即1字节)的倍数。在linux下size of word的结果是3字节(即char的3倍)。如果只考虑word的三个字段总共12位(3+6+3),需要两个char的16位即能装下,但是在linux的gcc实现下,第二个字段不能跨越两个char(为了对齐),所以三个字段各占一个字节。共3字节。但 一个字段能否跨越两个最长类型是由具体的实现决定的。

其次,我们讨论word内各个field的存储,这个和具体的实现有关。有的是从左向右分配的,有的是从右向左分配的。这个没有规律可言。

最后,对word中的field不能进行取地址操作,这是因为指针需要对齐。但可以对word进行取地址操作。

上述是爱站技术频道小编带给大家的C语言开发中内存分配的操作,希望能为大家带来帮助,相信在这里你一定能有所收获。

上一篇:指针和常量限定的详细分析

下一篇:C++开发中字节对齐的作用和原因

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载