1.联合体类型的声明
像结构体一样,联合体也是由一个或者多个成员构成,这些成员可以不同的类型。
但是编译器只为最大的成员分配足够的内存空间。联合体的特点是所有成员共用同一块内存空间。所以联合体也叫:共用体。
给联合体其中一个成员赋值,其他成员的值也跟着变化。
#include <stdio.h>
//联合类型的声明
union Un
{
char c;
int i;
};
int main()
{
//联合变量的定义
union Un un = {0};
//计算连个变量的⼤⼩
printf("%d\n", sizeof(un));
return 0;
}
上述代码的运行结果为什么呢?我们思考一下。按照上述所说我们的内存应该为最大成员的大小。
我们来运行一下:
2. 联合体的特点
联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小(因为联合至少得有能力保存最大的那个成员)。
#include <stdio.h>
//联合类型的声明
union Un
{
char c;
int i;
};
int main()
{
//联合变量的定义
union Un un = {0};
printf("%p\n", &(un.i));
printf("%p\n", &(un.c));
printf("%p\n", &un);
return 0;
}
我们来观察一下上面的代码的运行结果:
我们观察到这三个地址是一样的,这就说明了联合体是共用一个空间的。
我们再来看一个串代码:
#include <stdio.h>
//联合类型的声明
union Un
{
char c;
int i;
};
int main()
{
//联合变量的定义
union Un un = {0};
un.i = 0x11223344;
un.c = 0x55;
printf("%x\n", un.i);
return 0;
}
这个运行结果是什么呢?
我们仔细分析一下,可以画出如下图:
3.相同成员的结构体和联合体对比
代码1:
struct S
{
char c;
int i;
};
struct S s = {0};
代码2:
union Un
{
char c;
int i;
};
union Un un = {0};
我们来看图观察它们分别占用内存的情况:
我们发现联合体比结构体更节省空间,但是联合体的个个成员不能同时被使用。
4.联合体大小的计算
• 联合的大小至少是最大成员的大小。
• 当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。
我们发现在联合体中也存在对齐。
使用联合体是可以节省空间的,举例:
比如,我们要搞一个活动,要上线一个礼品兑换单,礼品兑换单中有三种商品:图书、杯子、衬衫。每一种商品都有:库存量、价格、商品类型和商品类型相关的其他信息。 如果我们用结构体写代码时就会发现有很多重复的代码,我们使用联合体的话就可以节省很多的空间。这个大家可以试一试。