JVM (1) :原码、反码、补码.md

概念

原码:将一个整数,转换成二进制,就是其原码。
如单字节的3的原码为:0000 0011;-3的原码为1000 0011。

反码:正数的反码就是原码;负数的反码是将原码中,除符号位以外,每一位都取反。
如单字节的3的反码为:0000 0011;-3的反码为1111 1100。

补码:正数的补码就是原码;负数的补码为反码+1。
如单字节的3的补码为:0000 0011;-3的原码为1111 1101。

在计算机中,正数是用原码表示的,如单字节3,在计算机中就表示为:0000 0011。
负数用补码表示,如单字节-3,在计算机中表示为1111 1101。

负数使用补码的原因

  1. 扩大表示范围
  • 单字节整数,无符号型,表示范围是[0,255],总共表示了256个数据。有符号型,其表示范围是[-128,127]。 java中的byte类型便是如此。

  • 无符号类型,0表示为0000 0000,255表示为1111 1111,可以表示256个数据,没啥问题。
      再看有符号的,若是用原码表示,0表示为0000 000。因为咱们有符号,所以应该也有个负0(虽然它还是0):1000 0000,反而-128表示不了。

  • 所以,计算机中,负数是采用补码表示。

  • 如 单字节-1,原码为1000 0001,反码为1111 1110,补码为1111 1111,计算机中的单字节-1就表示为1111 1111。

  • 单字节-128,原码貌似表示不出来,除了符号位,最大的数只能是127了,其在计算机中的表示为1000 0000。

  1. 简化减法运算

通过求补运算,获取对应的正数或负数。

如
                    原码           反码           补码
  -127 -〉127   1000 0001  -〉 0111 1110  -〉 0111 1111
    127 -〉-127   0111 1111  -〉 1000 0000  -〉 1000 0001
  -128 -〉128   1000 0000  -〉 0111 1111  -〉 1000 0000
  128 -〉-128   1000 0000  -〉 0111 1111  -〉 1000 0000
  可以发现,负数和正数求补的方法是一样的,负数正数均使用补码表示。
  对于实际使用场景,如java中的byte,取值范围为[-128,127]

在计算机中,我们可以看到,对其求补,得到的结果是其数值对应的负数。同样,负数也是如此。所以可以将减法变为加法,省去了减法器

  1. 无符号及带符号的加法运算可以用同一电路完成。

减法可以转成加法来实现,自然可以用同一电路实现。

微信扫一扫关注该公众号

欢迎关注我的微信公众号

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值