程序源码如下:
#include <stdio.h>
union Test {
unsigned char a;
unsigned short b;
unsigned int c;
};
int main(void)
{
union Test test;
printf("%lu\n", sizeof(union Test));
printf("%lu\n", sizeof(test));
printf("&test = %p, &test.a = %p, &test.b = %p, &test.c = %p\n", &test, &test.a, &test.b, &test.c);
test.c = 0x11223344;
printf("test.c = %x\n", test.c);
printf("test.a = %x\n", test.a);
printf("test.b = %x\n", test.b);
test.a = 0x88;
printf("test.c = %x\n", test.c);
printf("test.a = %x\n", test.a);
printf("test.b = %x\n", test.b);
return 0;
}
结果:
4
4
&test = 0x7fff4a0708c4, &test.a = 0x7fff4a0708c4, &test.b = 0x7fff4a0708c4, &test.c = 0x7fff4a0708c4
test.c = 11223344
test.a = 44
test.b = 3344
test.c = 11223388
test.a = 88
test.b = 3388
分析:
1、联合体的大小为最大成员的大小,在联合体union Test中unsigned int是最大的占4个字节。
2、联合体共用一块内存,其内存大小为最大成员的内存大小,所以所以成员的地址都一样,&test = &test.a = &test.b = &test.c。
3、给联合体某个成员赋值时会影响到另外一个成员的数值,如下图:
① 如果是小端模式:变量高位是放高地址、变量低位是放低地址。这里test.c=0x11223344指11为高位、44为低位。
② 栈区遵循“先进后出、后进先出”的规则,即打印的时候从高地址到地址依次打印,所以test.c打印值为11223344。
③ 从上图可以看出,test.a、test.b和test.c的起使地址都是44对应的地址,所以他们的地址都是一样的。
④ 如果test.a = 0x88,那么test.a、test.b和test.c本来的值都会发生改变,即test.a = 88,test.b = 3388,test.c = 11223388。