一.原码反码和补码的计算方式
1.对一个正数
二进制原码反码和补码完全相同。
例如 int i=150;
对应的二进制原码:00000000 00000000 00000000 10010110;
对应的二进制反码:00000000 00000000 00000000 10010110;
对应的二进制补码:00000000 00000000 00000000 10010110;
2.对一个负数
二进制的反码等于原码符号位不变,其它位置取反。
二进制的补码等于反码加一。
例如 int i = -150;
对应的二进制原码:10000000 00000000 00000000 10010110;
对应的二进制反码:111111111 11111111 11111111 01101001;
对应的二进制补码:111111111 11111111 11111111 01101010;
二.计算机为什么要引入补码
关于补码的作用,有如下解释:
(1)化减为加:
由于计算机CPU中只有加法器,没有减法器,所以在计算机采用原码做减法会存在一些问题:
例如1-1=0:
对计算机而言,它把这个减法看做是1+(-1)=0 。用二进制表示则为 0001+1001=1001, 这个结果为十进制的负1而不是0,很明显出现了错误。补码的出现很好的解决了这个问题