Bootstrap

有符号二进制加减法

补码

补码没有符号位,都是数值位!补码的意义:找到一个正数来表示原来的负数,让减法变为加法!

原码、反码、补码转换

正数:原码=反码=补码
负数:
原码除符号位不变,其他二进制位取反,得到反码
反码+1得到补码(符号位参与计算)
补码-1得到反码(符号位参与计算,可以理解补码没有符号位,都是数值位,因为补码的意义在于找到一个正数来代替原来的负数)
反码除符号位不变,其他二进制取反,得到原码

有符号二进制加减法(原码、反码、补码)

二进制加减法的符号位都是参与计算的。

二进制原码加减法

使用二进制原码进行加法是OK的,但是原码在做减法运算时,要比较两个数的绝对值,判断最终的符号,以绝对值大的数 减去 绝对值小的数,最终得到结果,过程太复杂。
如果计算机采用原码做加减法,并让符号位参与计算,对减法来说,结果是不正确的,例如:求2-1?
2的二进制为:00000010
-1的二进制为:10000001
那么:2-1=2+(-1)=00000010+10000001=10000011=-3
计算结果显然不正确。

计算机中使用的当然不是原码去表示一个数,而是补码。

二进制反码加减法

为了解决原码减法出现的问题,出现了反码计算减法,虽然反码的结果是正确的,但问题出现在“0”这个特殊值,例如 1-1=[0000 00001]反 + [1111 1110]反 = [1000 0000]原 = -0。
虽然+0和-0是一样的,但带符号的0是没有意义的,而且会出现[0000 0000]原和[1000 0000]原 两个编码表示0。

二进制补码加减法

反码计算出现了两个0的问题,于是出现了补码,可以解决0符号的问题。

以二进制数A和B为例,计算步骤:
1.转成补码后直接相加,符号位也参与运算,如果符号位产生了进位,必须舍去进位,得到的结果仍是补码
2.如果符号位是0,表示正数,即最终结果
3.如果符号位是1,表示负数,必须把补码转成原码才能得到正确的值(补码-1,然后取反)

以十进制数A和B为例,计算步骤:
1.求绝对值A+绝对值B的和,判断几位二进制位表示数值位,此外还有一个符号位,例如7+4=11,需要4个二进制位和1个符号位,一共5个二进制位
2.参见以“二进制数A和B为例的计算步骤”

案例

  • 案例1:求7+4?

解:
7+4=11,需要5个二进制位
原码:0 0111 + 0 0100
反码:0 0111 + 0 0100
补码:0 0111 + 0 0100 = 0 1011
结果:11

  • 案例2:求-7-4?

解:
原码:1 0111 + 1 0100
反码:1 1000 + 1 1011
补码:1 1001 + 1 1100 = 1 0101
补码为负数:1 0101 - 1 = 1 0100,取反得 1 1011,结果得 -11

  • 案例3:求7-4?

解:
原码:0 0111 + 1 0100
反码:0 0111 + 1 1011
补码:0 0111 + 1 1100 = 10 0011 = 0 0011(舍去进位)
结果为正数,即 0 0011 = 3

  • 案例4:求4-7?

解:
原码:0 0100 + 1 0111
反码:0 0100 + 1 1000
补码:0 0100 + 1 1001 = 1 1101
补码为负数:1 1101 - 1 = 1 1100,取反得 1 0011,结果得 -3

;