今天在调试网络程序时,查看日志文件,发现很多的处理数据都提示,包错误,数据不完整等信息,但是用wireshark捕包确发现这些报文都是正确的,并没有错误。后来经过仔细分析原因如下:
由于是异步网络通信,尽管我的每个报文大小都是1024以内,基本可以保证无分包现象,但是可能导致recvfrom收到包时,由于计算机还没有来得及把收到的整个数据都放到缓冲区,我就进行处理了,所以那些报文在某种意义上变成了2个,果然,在recvfrom前面加上了sleep函数,错误基本没有了。但是sleep多久,才能让错误包消失,且保证该程序的大数据量通信,需要不断测试,并且在不同机器上数值应该也不相同。