本文将讲述计算机中原码、反码和补码的计算以及他们存在的意义
一、原码、反码和补码的计算
1、原码的计算
计算机中一般都是八位二进制表示数据。一个数的原码是:(符号位)+(数的绝对值的二进制表示),其中负数的符号位为1,正数的符号位为0
举例说明:
十进制 | 原码 |
---|---|
85 | 0101 0101 |
-85 | 1101 0101 |
2、反码的计算
正数的反码是其本身,负数的反码是在其原码的基础上,符号位不变,其余的各个位取反。
举例说明:
十进制 | 原码 | 反码 |
---|---|---|
85 | 0101 0101 | 0101 0101 |
-85 | 1101 0101 | 1010 1010 |
3、补码的计算
正数的补码就是其本身,负数的补码是在其反码加1
举例说明:
十进制 | 原码 | 反码 | 补码 |
---|---|---|---|
85 | 0101 0101 | 0101 0101 | 0101 0101 |
-85 | 1101 0101 | 1010 1010 | 1010 1011 |
二、原码、反码和补码的意义
因为计算机做擅长做加法,所以人们就想如何把减法做成加法,这就是补码产生的原因
反码存在的意义在于算出补码。
而补码的意义在于:通过补码运算,可以把减法运算变成加法运算;而乘法可以用加法来做,除法可以转变成减法。
举个例子:
[ 52]原码: 0 0 1 1 0 1 0 0
[-52]反码: 1 1 0 0 1 0 1 1
[-52]补码: 1 1 0 0 1 1 0 0
这样当52加-52的时候就可以做如下加法:
0 0 1 1 0 1 0 0
+ 1 1 0 0 1 1 0 0
----------------------------
0 0 0 0 0 0 0 0
就完成了等于零的操作了