在今天搜这个问题的时候,我一直以为就是正常的超时重传、发送应答、拥塞控制、流量控制、三次握手四次挥手这种的,直到我看到这篇博文:校验和,其中说到了一个校验和,这个点对我来说还是蛮新颖的,经过大半天的学习搜索,大致理解了校验和的计算过程。
校验和
无进位:
比如我们需要发送到字段分别为:
字段a:0100
字段b:0001
将上述的俩字段相加得:0101
那么它的校验和就是俩字段相加的结果取反:1010
上面我们求出发送端的取反结果是1010,在接收端收到数据之后,我们以同样的方法对字段进行操作,如果我们得到发送端接收端的字段进行操作之后的结果不相等,那么传输一定有误,但是二者结果相等,数据不一定传输成功。(这句话我不是很懂,为啥二者结果相等,却不一定传输成功)
有进位:
上述的字段传输是没有进位的情况下,如果说字段有进位的情况下:
字段a :1000
字段b :1000
二者相加:1 0000
那么我们将进位的1加到后者0000的末尾得到了 0001,对所得结果0001取反:1110即得到了校验和,剩下的操作和上述的一样的。