联合体的特点及其大小的计算
【摘要】 联合体的特点及其大小的计算
上篇博客,笔者详细的介绍了联合的的使用方法!所以,笔者在这篇文章打算进行:联合体的特点及其大小的计算的讲述!!
联合体的特点:
联合体的成员是共用一块内存空间的,这样一个联合体变量的大小,至少是最大的成员的大小!(因为联合体至少得有能力保存最大的那个成员)!!
下面进入本篇文章的重中之重的部分:联合体大小的计算!!
在进行下面的内容之前,我们需要知道:
1.联合体的大小至少是最大成员的大小!!
2.当最大成员的大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍!
3.联合体的大小,不一定总是最大成员的大小!
下面请看笔者代码部分:
#include <stdio.h>
union un
{
char arr[5]; //5个字节
int i; //4个字节
};
int main()
{
printf("%d\n", sizeof(union un));
return 0;
}
对于这个代码,该联合体成员的大小一个为5,一个为4,但是最后运行出来的结果却为:8!!这个又是为什么呢??
对联合体的内容进行分析:
因此,上面再内存中的分配情况为:
笔者在借用几个联合体的代码,来带领大家分析一下:
1.
union un
{
short s[6];
int i;
};
对于该段联合体的分析情况为:
在这里,我们需要铭记的是:最大成员的大小是:最大对齐数的整数倍!!
2.将上面的数组short s[6]更改为:short s[7]
union un
{
short s[7];
int i;
};
对于该段联合体的分析情况为:上述联合体的大小为:16
本文到此就结束了!若各位老铁有不懂得地方,请私聊笔者,或者评论区发一评论哟!!
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)