为什么要有原码反码和补码不同的编码
数值在计算机中表示形式为机器数,计算机只能识别0和1,使用的是二进制,而在日常生活中人们使用的是十进制,"正如亚里士多德早就指出的那样,今天十进制的广泛采用,只不过我们绝大多数人生来具有10个手指头这个解剖学事实的结果。 尽管在历史上手指计数(5,10进制)的实践要比二或三进制计数出现的晚。"(摘自有空大家可以看看哦~,很有意思的)。为了能方便的与二进制转换,就使用了十六进制(2 4)和八进制(23)。下面进入正题。 数值有正负之分,计算机就用一个数的最高位存放符号(0为正,1为负)。这就是机器数的原码了。假设机器能处理的位数为8。即字长为1byte,原码能表示数值的范围为 (-12...全部
数值在计算机中表示形式为机器数,计算机只能识别0和1,使用的是二进制,而在日常生活中人们使用的是十进制,"正如亚里士多德早就指出的那样,今天十进制的广泛采用,只不过我们绝大多数人生来具有10个手指头这个解剖学事实的结果。
尽管在历史上手指计数(5,10进制)的实践要比二或三进制计数出现的晚。"(摘自有空大家可以看看哦~,很有意思的)。为了能方便的与二进制转换,就使用了十六进制(2 4)和八进制(23)。下面进入正题。
数值有正负之分,计算机就用一个数的最高位存放符号(0为正,1为负)。这就是机器数的原码了。假设机器能处理的位数为8。即字长为1byte,原码能表示数值的范围为 (-127~-0 0~127)共256个。
有了数值的表示方法就可以对数进行算术运算。但是很快就发现用带符号位的原码进行乘除运算时结果正确,而在加减运算的时候就出现了问题,如下: 假设字长为8bits ( 1 ) 10- ( 1 )10 = ( 1 )10 ( -1 )10 = ( 0 )10 (00000001)原 (10000001)原 = (10000010)原 = ( -2 ) 显然不正确。
因为在两个整数的加法运算中是没有问题的,于是就发现问题出现在带符号位的负数身上,对除符号位外的其余各位逐位取反就产生了反码。反码的取值