欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

C > > 右移算子的原理和概念。

最编程 2024-06-30 19:31:58
...

1、右移位于左移位不同

左移位 不管是 逻辑移位 算术移位 都是低位补0;

右移位 的 逻辑移位和算术移位不同, 算术移位高位补符号位,逻辑移位 高位补0;

右移位 使用逻辑移位的话 需要强制转换成unsigned 无符号型;

2、右移位的计算方法

以 a=113 , a >>2 为例

113: 0111 0001

>>2: 0001 1100

即 28; a>>2 = 28;

以 b=-113 , b>>2 为例

-113 : 1111 0001

反码: 1000 1110

补码: 1000 1111

>>2 : 1110 0011 (高位补符号位1)

再反码:1001 1100

再补码:1001 1101

即 b>>2 = -29;

正数的 补码是其本身,所以不用反复求补码; 负数则不同。

另; 移位的位数 不能为负值 , a>>-2 或者a<<-2 是错误的。

推荐阅读