java二进制 原码、反码、补码 非运算

概念

原码:计算机中的二进制表现方式,首位为符号位
反码:
正数:与原码相同
负数:原码除符号位以外,1变0,0变1
补码:
正数:与原码相同
负数:反码+1

原码的概念需要注意一下,原码是表现方式,是展示给我们看的。
补码才是计算机真正使用的,这个地方需要注意一下,要不然很多地方会晕的。

DEMO

这里做一下非运算的demo,因为非对比其它几个运算会绕一下,与、或、异或的形式比较直接,就不展示了。
代码如下:
java二进制 原码、反码、补码 非运算
结果展示:
java二进制 原码、反码、补码 非运算
在这里详细说明一下为什么为会是这个效果:
3的补码如下

3(补码) -> 0000 0011

进行非运算后

3(补码) -> 1111 1100

其实此时已经是-4了,计算机可以识别了,但是这不是需要展示的
还应该转成原码才是展示的结果,流程:补码->反码->补1

3(反码 符号位不变,其它位转换)->1000 0011
3(补1)->1000 0100

上面补1后的结果才是展示的结果
首位的符号位 1表示 负数,后面的 0100表示 4
其结果为-4

其实质上并不难,所困惑的地方就在于机器使用的是补码,给我们展示的时候是原码,只需要明白这个地方的问题,就能顺利的理解问题了。