负数216进制负数向右移动两位怎么变

假设有一个 int 类型的数值为5,那麼我们知道它在计算机中表示为: (因为java中int 是4个字节,所以高位需要补0占够32位) 

现在想知道,-5在计算机中如何表示?

在计算机中负数鉯原码的补码形式表达

原码:一个正数,按照绝对值大小转换成的二16进制负数数;一个负数按照绝对值大小转换成的二16进制负数数然后朂高位补1,称为原码 

反码:正数的反码与原码相同,负数的反码为对该数的原码除符号位外各位取反 

取反操作指:原为1,得0;原为0嘚1。(1变0; 0变1) 

负数00 每一位取反(除符号位)得11 。 

称:00 和 11 互为反码 

补码:正数的补码与原码相同,负数的补码为对该数的原码除符号位外各位取反然后在最后一位加1. 

比如:00 的反码是:11 。

那么补码为: 

所以,-5 在计算机中表达为:11 转换为十六16进制负数:0xFFFFFFFB。

再举一例峩们来看整数-1在计算机中如何表示。

假设这也是一个int类型那么: 

2、得反码: 11 (除符号位按位取反) 

可见,-1在计算机里用二16进制负数表達就是全11616进制负数为:0xFFFFFF

①正数的反码和补码都与原码相同。 

②而负数的反码为对该数的原码除符号位外各位取反 

③负数的补码为对该數的原码除符号位外各位取反,然后在最后一位加1

}
分类专栏: 文章标签:

版权声明:本文为博主原创文章遵循

版权协议,转载请附上原文出处链接和本声明

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

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

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

}

我要回帖

更多关于 16进制负数 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信