请问nio中对于断包的处理,断包数据应该存放在哪里?

Pandora Heart 2018-10-09 03:41:50
最近想用nio实现长连接,为了解决断包和粘包的问题,大体思路如下:
数据格式:消息头(4字节)+消息体
服务端接收到数据,判断是否是断包,如果是,则将该断包存储,然后继续下一次接收数据,然后将这两个数据合并,再读取

现在的问题是,当我只有一个连接时,我可以将数据存储进类的成员变量中:
public class NIOServer {
//存放断包的缓冲区
ByteBuffer cacheBuffer = ByteBuffer.allocate(100);
}

但是当我有两个连接时,这两个连接的断包都会存储进这个缓冲区,造成数据污染,所以想问问一般这种断包数据怎么存放?
...全文
207 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧