今天在测试程序的时候,发现int型的数右移后得到的结果与自己所想要的不一样,于是查找原因,最终发现是逻辑右移与算术右移的问题。
系统为32位,以0x80000000(10000000000000000000000000000000)测试。
代码:
static int shift_test(void)
{
int signed_value = 0x80000000;
unsigned int unsigned = 0x80000000;
printf("%x, %x\n", signed_value >> 1, unsigned_value >> 1);
return 0;
}
其输出结果为:
c0000000, 40000000
比较结果得:
c0000000(11000000000000000000000000000000),移入的位填了1,算术右移;
40000000(01000000000000000000000000000000),移入的位填了0,逻辑右移。
逻辑右移移入的位用0补位,算术右移移入的位用符号位补位。
而逻辑左移与算术左移则相同,补0。