原码、反码、补码及右移、无符号右移解析


原码:

使用高位作为符号位。最高位为0时表示正数,最高位为1时则表示为负数。其余位使用此数字数值本身二进制的绝对值表示。

反码:

使用高位作为符号位。最高位为0时表示正数,最高位为1时则表示为负数。正数的反码还是正数本身;负数的补码即在原码的基础上,符号位不变,其他位取反。

补码:

使用高位作为符号位。最高位为0时表示正数,最高位为1时则表示为负数。正数的补码就是正数本身,负数的补码就是其原码取反加一。

下面举例:

右移(>>):

右移即带符号右移。对于正数的右移,移位过程中、高位补零;对于负数的右移,因为负数在内存中是以补码形式存在的,所有首先根据负数的原码求出负数的补码然后保证符号位不变,其余位向右移动到X位,在移动的过程中,高位补1.等移位完成以后,然后保持符号位不变,其余减一按位取反,得到移位后所对应数的原码。即为所求。

无符号右移(>>>):

 不论正数还是负数,移位过程中高位均补零。

举例:

正数右移和无符号右移是都是高位补零

负数右移

负数无符号右移

在机器中,数的二进制码都是其补码。

① 负数的右移:需要保持数为负数,所以操作是对负数的二进制位左边补1。如果一直右移,最终会变成-1,即(-1)>>1是-1。

② 负数的左移:和正数左移一样,在负数的二进制位右边补0,一个数在左移的过程中会有正有负的情况,所以切记负数左移不会特殊处理符号位。如果一直左移,最终会变成0。

总结:

对于右移,因为牵扯到符号位,所以正数右移左边补0,负数右移左边补1。

对于左移,因为不牵扯符号位,所以右边不论正数还是负数都补0。

原文链接:https://blog.csdn.net/yo_bc/article/details/74511066

原文链接:https://blog.csdn.net/weixin_43689776/article/details/99979963


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM