采用二进制反码运算求和

具体规则:(求到反码后的运算规则)

1,从低位到高位逐列计算

20 +0=0 0+1=1 1+1 =10(1进位)

         3,最高位进位的话要加到最后的结果上

 

直接在原码基础上求反码和:

1,从低位到高位逐列计算

20 +0=10 0+1=1 1+1 =0(其实是一样啦,这里00-11后相加是不是10哦,向最高位进1

                 3,最高位进位的话要加到最后的结果上

 

 UDP校验

 

UDP校验

 

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.csdn.net/dingmin1860/article/details/48268927>

 

 

相关文章:

  • 2021-09-25
  • 2021-11-28
  • 2021-08-15
  • 2021-07-20
  • 2021-11-22
猜你喜欢
  • 2022-12-23
  • 2021-10-28
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-08-05
相关资源
相似解决方案