原码:
使用高位作为符号位。最高位为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