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