使用java7的AIO异步读取数据时发现有重复读取的现象
使用如下代码读取socket channel中的数据到缓冲区中,程序对读取到的数据进行处理。
如果读取到的一批数据中,存在半个message的情况下,程序会将本次剩余的半个message数据保存起来,
等下次读取到数据后,进行合并,然后判断程序是否能正常执行,若不能则表示第二次读取到的数据与
之前保存起来的半个message数据不是同一批,则程序继续重新处理第二次读取到的数据,然后第三次读取
后再合并,再试着处理...直到合并后能成功处理。
现在发现,合并后能成功处理,但是后面仍然会读取到已经处理过的半个消息的后半段数据,不知道各位大侠
有没有遇见过这种情况?
socket.read(byteBuffer, null, new CompletionHandler<Integer, Void>() {
@Override
public void completed(Integer result, Void attachment) {
if(result==-1){
close();
return;
}
byteBuffer.clear();
if (result > 0) {
byteBuffer.limit(result);
LOG.debug("server socket [{}] get " + result + " data from client:{}", clientIdentifier, getString(byteBuffer, result));
if (!connectted) {
handleConnect();
} else {
if (remainingData != null) {
combineBuffer();
}
while (byteBuffer.position() < result) {
doProcess();
}
}
}
byteBuffer.clear();
socket.read(byteBuffer, null, this);
}
@Override
public void failed(Throwable exc, Void attachment) {
LOG.error("Server socket [{}] read failed,{}.", clientIdentifier, exc.toString());
close();
}
});
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
另外还有个问题,就是每次read到的字节数是不一样的,我的消息大小定为2kb,通常情况下,客户端每发一个消息,那么server端就会read到2kb的数据,但是偶尔会有只read到1kb或者几百个字节的情况,有没有人知道这是怎么回事?