Java开发之————二进制正负数的原码、反码、补码之间的转化

前言

计算机都是使用二进制的补码进行计算。原码、反码、补码分正负数来讲,下面将分别进行讲解。

原码、反码、补码

整数

正数的二进制原码、反码、补码都是相同的

负数

负数的二进制原码

概念

先计算该负数绝对值的二进制。之后对其每个数“取反”,然后加一。

实例

比如-32

  • 第一步:32(10)=00100000(2)
  • 第二步:求反:11011111
  • 第三步:加1:11100000

负数的反码

概念

等于原码的最高位不变,其余取反。

实例

比如-32

  • 原码为:11100000
  • 反码为:10011111

负数的补码

概念

等于原码的最高位不变,其余取反,然后加一。

实例

比如-32

  • 第一步,原码为:11100000
  • 第二步,最高位不变取反:10011111
  • 第三步,加一得补码:10100000

其他

参考:二进制正负数的原码、反码、补码之间的转化