检验和算法所用的反码与补码的不同

本文深入探讨了计算机中使用的补码(two's complement)与反码(one's complement)体系的区别。补码体系中最高位进位会被丢弃,而反码体系则将进位加给最低位。文章通过具体实例解释了两种体系下数值的表示方法及其运算原理。
大部分计算机使用的都是补码(two complement)体系,这种体系中最高位即符号位产生的进位会被丢弃,如1100(-4)+1111(-1)=1011(-5);这种算法 取反后加1 相当于对十进制数取相反数,取反相当于取相反数减1,即~x=-x-1。
而IP数据报与UDP数据报检验和的算法采用反码体系(one complement),这种体系中最高位产生的进位会加给最低位,如1110(-1)+1001(-6)=0111+0001=1000(-7)。用这种算法 取反 相当于对十进制取相反数。检验和算法实际为x+(~x)=x+(-x)=0(反码全为1)取反后全为0。
四位二进制数
十进制(反码)
十进制(补码)
0000
0
0
0001
1
1
0010
2
2
0011
3
3
0100
4
4
0101
5
5
0110
6
6
0111
7
7
1000
-7
-8
1001
-6
-7
1010
-5
-6
1011
-4
-5
1100
-3
-4
1101
-2
-3
1110
-1
-2
1111
0
-1

转载于:https://www.cnblogs.com/Minstrel223/p/10980141.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值