原码、反码、补码、负数的移位

来源:互联网 发布:斯托克斯矩阵 编辑:程序博客网 时间:2024/04/30 04:35

正数的原码、反码、补码都相同;
负数的反码为原码除符号位,其他位都取反,补码为反码加1。

正数的移位(+5为例,左/右移两位:0000 0101):
左移m位:最左边的m位将丢弃,同时在最右边补上零(0001 0100)
右移m位:最右边的m位将丢弃,同时在最左边补上零(0000 0001)

负数的移位:由于存在符号位,符号位在移位过程中是不动的(以-5为例,左/右移两位:1111 1011(-5的补码表示))
左移m位:符号位不变,从符号位下一位开始,左边的m位将丢弃,同时,最右边m位补零。这一点跟正数是一样的(1110 1100)
右移m位,符号位不变,从符号位下一位开始,右边的m将丢弃,同时最左边m位补1。这是跟正数的区别(11111110)

0 0