#include <stdio.h> int main(void) { unsigned i = 0xcffffff3; long j=0xcffffff3; int k=0xcffffff3; printf("num: %x ",0xcffffff3 >> 2); printf("i: %x ",i >> 2); printf("j: %x ",j >> 2); printf("k: %x ",k >> 2); }
打印结果
sh-3.2# ./a.out num: 33fffffc i: 33fffffc j: 33fffffc k: f3fffffc
无符号的0xcffffff3 转换成二进制为 1100 1111 1111 1111 1111 1111 1111 0011
右移两位后为 0011 0011 1111 1111 1111 1111 1111 1100 转换成16进制为 0x33fffffc
如果是有符号
1100 1111 1111 1111 1111 1111 1111 0011 右移后为 1111 0011 1111 1111 1111 1111 1111 1100
转换成16进制: 0xf3fffffc
也就是有符号的不管右移多少位,并不是最高位补1,而是每次右移时最高位都补1