1、前言-机器数和真值
我们首先要了解机器数和真值的概念。
1.1 机器数
一个数在计算机中的二进制表示形式,叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号,正数为0,负数为1。
比如:十进制的数+3,计算机字长为8位,转换成二进制就是00000011,如果是-3,就是10000011.那么这里的00000011和10000011就是机器数
1.2 真值
真值可以理解为真正的值,一般用十进制表示,也可以用二进制表示。
因为第一位是符号位,所以机器数的形式值就不等于真正的数值。例如上面有
符号数10000011,其4最高位1代表负,其真正数值是-3而不是形式值131(10000011转换成十进制等于131).所以,为区别起见,将带符号位的机器数对应的真正数值称为机器数的真值。
例:00000001的真值为+1,10000001的真值为-1
2、原码
原码的表示:正数用0来表示,负数用1来表示,数值部分不变。
举例:0可表示为0000,-0为1000,-7为1111,5为0101(在此举例皆为4位原码)
缺点:0的表示不唯一,不利于编程;加减运算方式不统一,同号的数要比较绝对值才能做减法;额外的符号位不利于硬件设计。
3、反码
反码的表示:正数的反码是它本身;负数的原码是在其原码的基础上符号位不变,其余各位取反。
举例:+1的8位反码为00000001,-1的8位反码为11111110(-1的8位原码是10000001)
出现原因:反码的出现是为了解决原码做减法的问题。
4、补码
补码:正数的补码与原码一致,负数的补码是对原码按位取反加1,符号位不变。
5、计算示例
举例:+1的八位原码:0000 0001,补码:0000 0001
-1的原码:1000 0001,
补码:
第一步取反(实际是求补码):
1111 1110
第二步加1(补码的基础上加一):
1111 1111