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对象没有读完
本文探讨了Netty框架中ByteToMessageDecoder的decode方法被多次调用的原因。作者通过debug发现该方法使用同一ByteBuf对象,且ridx值变化。深入解读源码注释后得知,只要ByteBuf未完全读取完毕,decode方法就会持续调用。
1432





