定义:
union是一种类似与struct的联合体,叫做共同体。他的定义格式是:
union 共同体名{
成员列表
};
特点:
结构体和共同体的区别在于:
- 结构体的各个成员会占用不同的内存,相互之间没有影响;而共同体的所有成员占用同一段内存,修改一个成员会影响其余所有成员。
- 结构体占用的内存大于等于所有成员占用的内存的之和。(成员之间可能会存在缝隙)。
- 共同体占用的内存等于最长的成员占用的内存
- 共同体使用了内存覆盖技术,同一时刻只能保存一个成员的值,如果对新的成员复制,就会把原来成员的值覆盖掉。
代码块:
union{
int n;
char ch;
double f;
} a, b, c;
在共同体中,成员f占用的内存最多,为8个字节。所以这个共同体(a,b,c)也占用8个字节的内存。
运行代码:
#include <stdio.h>
union data{
int n;
char ch;
short m;
};
int main(){
union data a;
printf("%d, %d\n", sizeof(a), sizeof(union data) );
a.n = 0x40;
printf("%X, %c, %hX\n", a.n, a.ch, a.m);
a.ch = '9';
printf("%X, %c, %hX\n", a.n, a.ch, a.m);
a.m = 0x2059;
printf("%X, %c, %hX\n", a.n, a.ch, a.m);
a.n = 0x3E25AD54;
printf("%X, %c, %hX\n", a.n, a.ch, a.m);
return 0;
}
运行结果:
4, 4
40, @, 40
39, 9, 39
2059, Y, 2059
3E25AD54, T, AD54
结论:
想要理解上面的输出的结果。就需要理解成员在内存之间的分布,以上面的data为例。各个成员在内存中的分布如下所示:
成员之间在内存中:都会对齐到一头,对于ch来说,它占用的是第一个字节;对于m来说,它占用的是前两个字节,n就是前四个字节。
也就是说,修改ch的时候,会影响m和n的前一个字节。如果修改n的字节,那么对于ch和m来说就是修改全部的内存。