文章目录
一、计算机中数值数据的编码和表示
▪ 机器数和真值 – 实际运算中,数是有正负的,计算机中数也有正负,通过用一个数的最高位 表示符号,如果字长为8位,分别为D7~~D0,那么D7为符号位,0表示正 数,1表示负数,D6~D0为数值位
– 例如:
▪ 11010111 = -87
▪ 这样,在计算机中,连同符号一起数码化的数,就被称为机器数, 如上面的11010111;而使用正负号加其绝对值的表示方法,称 为该数的真值,如-87
二、原码
▪ 原码是指将最高位作为符号位(0表示正,1表示负),其它数字 位代表数值本身的绝对值的数字表示方式 – 数字6在计算机中原码表示为:0000 0110 – 数字-6在计算机中原码表示为:1000 0110
▪ 以上是在8位计算机中的原码表示,如果在32位或16位计算机中, 表示方法是一样的,只是多了几个0而已
▪ 有了数值的表示方法就可以对数进行算数运算,但是很快就发现 用带符号位的原码进行乘除运算时结果正确,而在加减运算的时 候回出现问题,如下:
▪ (1)10 - (1)10 = (1)10+(-1)10 = (0)10
▪ (00000001)原+(10000001)原=(10000010)原=(-2)
▪ 显然是不正确的
三、反码
▪ 反码表示规则为