采用二进制反码运算求和
具体规则:(求到反码后的运算规则)
1,从低位到高位逐列计算
2,0 +0=0 0+1=1 1+1 =10(1进位)
3,最高位进位的话要加到最后的结果上
直接在原码基础上求反码和:
1,从低位到高位逐列计算
2,0 +0=10 0+1=1 1+1 =0(其实是一样啦,这里00-》11后相加是不是10哦,向最高位进1)
3,最高位进位的话要加到最后的结果上
0100 1111 0001 1010
0111 1010 0001 1000
0011 0110 1100 1100最后最高位有进位,结果加1
变为: 0011 0110 1100 1101
===========================================
在发送数据时,为了计算数据包的检验和。应该按如下步骤:
1、把校验和字段设置为0;
2、把需要校验的数据看成以16位为单位的数字组成,依次进行二进制反码求和;
3、把得到的结果存入校验和字段中
在接收数据时,计算数据包的检验和相对简单,按如下步骤:
1、把首部看成以16位为单位的数字组成,依次进行二进制反码求和,包括校验和字段;
2、检查计算出的校验和的结果是否为0;
3、如果等于0,说明被整除,校验和正确。否则,校验和就是错误的,协议栈要抛弃这个数据包。
书上有一句话:“如果校验和的计算结果为0,则存入的值为全1(65535),这在二进制反码计算中是等效的”
来自 http://blog.youkuaiyun.com/dingmin1860/article/details/48268927