计算机中正数与负数的存储方式

本篇主要详细讲解计算机的原码,反码与补码
一,机器数与真值
1,机器数
机器数:一个数在计算机中的二进制表示形式
比如十进制中的数 +3 ,如果用字长为8位的存储单元来存储,则二进制表示为00000011。如果是 -3,二进制表示为10000011 。
说明机器数是带符号的,其中最高位0表示正数,1表示负数。
2,真值

列如上面的有符号数1000 0011表示-3,而不是无符号数131。为了区分,将带符号位的机器数对应的真值称为机器数的真值。

机器数 00000011的真值 = +000 0011 = +3 机器数 10000011的真值 = -000 0011 = -3
二,原码,反码,补码的基础概念和计算方法
原码,反码,补码只是计算机存储数字的一种方式。
1,原码
原码就是用第一位表示符号位,其余位表示值,比如8位的二进制数

[+1]= 0000 0001

[-1]= 1000 0001

因为第一位为符号位,所以8位二进制数的取值范围为

[1111 1111 , 0111 1111] 即 【-127,+127】

2,反码
反码是在原码的基础上符号位不变,其余的位数取反,比如

[+3] = 00000011 =0111 1100

[-3] = 1000 0011 =1111 1100

3,补码
正数的补码为它本身,比如

[+3] = 0000 0011 =0000 0011

负数的补码为其反码+1

[-3] = 1000 0011 =1111 1100=1111 1101

三,为何要用原码,反码,补码
通过上述我们知道计算机有三种编码方式,对于正数三种编码方式的结果都相同

[+3] = 0000 0011 =0000 0011=0000 0011

[-3]= 1000 0011 =1111 1100=1111 1101

首先, 因为人脑可以知道第一位是符号位, 在计算的时候我们会根据符号位, 选择对真值区域的加减。 但是对于计算机, 辨别"符号位"显然会让计算机的基础电路设计变得十分复杂! 于是人们想出了将符号位也参与运算的方法。
我们知道, 根据运算法则减去一个正数等于加上一个负数, 即: 3-3 = 3 + (-3) = 0 , 所以机器可以只有加法而没有减法, 这样计算机运算的设计就更简单了。
原码将符号位参与运算的计算方法如下

3-3=3+(-3)= 0000 0011 + 1000 0011 = 1000 0110 = -6

如果用原码表示让符号位参与运算,对于减法来说结果显然不正确,这就是计算机内部不适用原码表示一个数的原因。
反码的计算方法如下

3-3=3+(-3)= 0000 0011 + 1000 0011 = 0000 0011 +1111 1100 = 1111 1111 = 1000 0000 = -0

可以看到用反码计算减法结果真值部分是正确的,但数字0却有两种编码方式+0与-0,显然0带符号位没有任何意义。而且会有0000 0000和1000 0000两个编码表示0。
补码的出现就解决了0的符号以及两个编码的问题
补码的计算方法如下

3-3=3+(-3)= 0000 0011 + 1000 0011 = 0000 0011 +1111 1100 = 0000 0011 + 1111 1101 =0000 0000 = 0000 0000 = 0

这样0用[0000 0000]表示,而以前出现问题的-0则不存在了。而且可以用[1000 0000]表示-128

(-1)+(-127)= 1000 0001 + 1111 1111 = 1111 1110 +1000 0000 = 1111 1111 + 1000 0001 =1000 0000 = -128

使用补码运算修复了0的编码表示,而且还能表示一个最低数,-128并没有原码和反码表示。8位二进制数表示的范围为[-128,127],也就是[-27,27-1],其他同理。

你可能感兴趣的:(计算机中正数与负数的存储方式)