联合体的存放顺序问题

C语言中的联合体是有固定存放顺序的,一定是低位存放在低地址,高位存放在高地址,这是很多开发者尤其是PC平台的开发者很容易忽视的一个特性。

我们知道,计算机平台有一个大小端的区别,小端系统中数据低位存放在低地址,大端系统中数据则低位存放在高地址。比如一个双字节整数,分配的地址是0x4A00和0x4A01两个字节,要存储1这个数字的时候,小端系统中0x4A00存放0,0x4A01存放1,大端系统中0x4A00存放1,0x4A01存放0。

可以看到,在小端系统中,联合体的存放顺序和系统是一致的,但到了大端系统,就和系统相反了。如果你习惯于使用小端系统,直接用类型变量代替联合体不会出现问题,但在大端系统中却会出现错误,甚至程序崩溃。因此对联合体的运用,最保险的办法是严格定义联合体变量,而不是贪图方便,直接用基本类型变量代替,这样当跨平台时才能尽量避免错误。

比如以下的代码,在x86、mips上都是没问题的:


semctl(id, 0, SETVAL, 1);


但是在PowerPC上,这语句就会导致错误,因此应该写成这样:


union semun un;
un.val = 1;
semctl(id, 0, SETVAL, un);
 
  


你可能感兴趣的:(语言与算法,Linux,交叉编译)