最近在看到UNIX 网络编程中,对主机字节序判断的一个小程序时,对union的运用让我有点疑惑,如下代码:
union{
short s;
char c[sizeof(short)];
}un;
un.s = 0x0102;
printf("%s\n", un.c);
if(sizeof(short) == 2)
{
if(un.c[0] == 1 && un.c[1] == 2)
printf("big-endian\n");
else if(un.c[0] == 2 && un.c[1] == 1)
printf("little-endian\n");
else
printf("unknown\n");
}
else
printf("sizeof(short) = %d\n", sizeof(short));
疑惑:为什么给s赋值之后,可以直接访问变量c来进行大小端的判定
后来看了下union的一些特性:
1、union中可以定义多个成员,union大小由最大的成员的大小来决定
2、union成员共享同一块大小的内存,一次只能使用其中的一个成员
3、对某一个成员赋值,会覆盖其他成员的值(前提是成员所占字节数相同,当不同时,指挥覆盖相应字节上的值)
4、union的存放顺序是所有成员都从低地址开始存放的
看完这些特性,上面的疑惑就迎刃而解了