Netty中ByteToMessageDecoder中的decode方法执行多次的问题

来源:互联网 发布:name域名转出 编辑:程序博客网 时间:2024/05/22 01:57

Netty中ByteToMessageDecoder中的decode方法执行多次的问题

最近跳进了netty的一个坑,我客户端只发送了一个报文给服务端,服务端也只返回了一个报文,可是,ByteToMessageDecoder的decode方法却执行了三次,通过debug,看到decode方法中的ByteBuf引用计数对象为:

ridx widx cap 0 64 4096 60 64 4096 62 64 4096

通过以上表格可以知道,decode方法执行的三次用的是同一个ByteBuf对象,只是ridx不同
再查看decode方法的源码注释如下:This method will be called till either the input
has nothing to read,意思是说:ByteBuf对象的数据没有读完的话,decode方法会一直调用

至此,问题得以解决了,就是ByteBuf对象没有读完

0 0
原创粉丝点击