TCP Socket 分包办法
最近需要APP从服务端(C++)获取数据,协议规定使用TCP,且数据量较大。一半路由器的MTU为1500或者1492,所以必然存在分片,客户端收到的数据也存在粘包现象,这是就需要对数据包进行分包处理。这里采用缓冲数组来解决分,直接上代码,由于电脑不能复制,只能上图片了,有空再敲吧。
这里我用到的是安卓的HandlerThread,来处理数据和分发回调。接收数据的线程只管在收到数据,发消息给该线程,然后继续接收数据,发消息。HandlerThread线程使用消息机制,负责将收到的数据先复制到缓冲数组,然后判断数据,如果够一包数据就解析并分发,不够就继续等待消息到来后再判断。
这样分开线程处理,提高效率。如果各位还有更好的方法,不吝赐教!

针对APP从C++服务端获取大量TCP数据时遇到的分片与粘包问题,本文介绍了一种利用HandlerThread和缓冲数组的分包处理方法。通过分线程处理,提升效率。
3102

被折叠的 条评论
为什么被折叠?



