前序:相信熟悉网络的同学都知道,TCP是面向流的,啥是面向流?谢希仁之<<计算机网络>>中有段话,个人觉得描述得非常贴切:
这就是传输层提交给应用层的发生粘包和拆包的根本原因,TCP协议视一切如流,它并不知道上层应用需要的是啥,只是在保证有序的情况下在适当的时机将数据提交给应用层处理。
现在业界解决的粘包和拆包的方案主要有三个:
1:消息定长,例如每个报文的大小固定的200字节。这个解决方案估计工业界用的很少。
2:在包尾用特殊字符进行分割,例如用换行符
3:将消息分为消息头和消息体,消息头表示消息的总长度