1、为什么要使用反码和补码
①计算机中实际上并没有减法,而只有加法,减法用增加一个数的相反数实现。
即1 - 1在计算机中的实际预算中为 1 + (-1)
而此时如果使用原码进行运算:0 0000001(1) + 1 0000001(-1) = 1 0000010(-2),会出现运算错误的情况。
为了解决原码做减法出错的问题,出现了反码
0 0000001【1反】 + 1 1111110【-1反】 = 1 1111111【0反】 ==> 1 0000000【0原】
但是使用反码时,0既可以用0表示,也可以用-0表示。然而这是没有意义的,所以出现了补码
0 0000001【1补】 + 1 1111111【-1补】 = 0 0000000【0补】 ==> 0 0000000【0原】
并且在使用补码时,原来-0所占位置可以用来表示该长度所能表示的最小的数,若为8位则能够表示-128。
(-1)+(-127)= -128
1 1111111【-1补】 + 1 0000001【-127补】 = 1 0000000【-128补】 ==> 1 0000000【-128原】
2、其他乱七八糟问题
①取相反数
5取相反数 0 0000101【5原5反5补】 1 0000101【-5原】 1 1111010【-5反】 1 1111011【-5补】
由上可看出常规情况下一个数取相反数为所有数字取反加一
但是对于1 0000000【-128补】所有数字取反加一后仍然是它本身
如有错漏,欢迎指出。
参考文章:原码, 反码, 补码 详解