udp的特点是不可靠,不连接,数据发过去就完事,至于对方收没收到就不管了。
在使用udp进行通信的时候,要在应用层做分组、排序、组包、校验等工作。
发送方现将要发送的数据切片,所有的切片组成一组,标上组号,每个切片根据原始数据的顺序有个组内编号。
发送的时候,每次发送一个切片,并等待接收数据接收方反馈收到数据的信息,如果没有接收到数据接收方的反馈信息就继续发送,接收到数据接收方发送的反馈信息位置。
数据接收方接收到数据后先给发送方发送一个数据接收成功的反馈,然后对数据进行分组存储。存储之前要先检验一下该块数据是否已经接受过了,因为虽然接收方成功的接收到了数据,并发送了反馈信息给发送方,但发送方可能没有接收到反馈信息,发送方会判定是发送失败,从而再次发送该块数据,从而导致了接收方对同一块数据重复接收了两次。
当接收方接收到的数据块数与发送方发送的总块数相同时,说明该数据已经全部接收完成,对数据进行排序组合,最后再进行校验,至此一个数据发送完成。
为了组号处理方便,直接用完整信息的hash作为组号,数据重新组装完成后可以直接用组号进行校验。每一组存到一个map里,有map根据序号自动排序。
//数据切片
void P2PNode::sendBlockChain()
{
P2PMessage mess;
int i = 0;
BlockC