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对象没有读完