博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Netty笔记:ReplayingDecoder中buffer使用的一点小陷阱
阅读量:4214 次
发布时间:2019-05-26

本文共 1042 字,大约阅读时间需要 3 分钟。

   ReplayingDecoder的原理是阻塞IO,当没有读到足够的数据时,会抛出RelayError,进入以后的LOOP中不断check是否有足够的数据。因此每次读取时我们倒要check一下buffer的数据。为此Netty提供了ReplayingDecoderBuffer这样一个代理类封装原有的buffer。以readInt为例,首先要检查是否有4个字节可读。不满足抛出ReplayError。

@Override    public int readInt() {        checkReadableBytes(4);        return buffer.readInt();    }    private void checkReadableBytes(int readableBytes) {        if (buffer.readableBytes() < readableBytes) {            throw REPLAY;        }    }
 
     陷阱在哪呢?  我在ReplayingDecoder中使用buffer的readableBytes()发现总是一个很大数字,这个数据非常大明显超出我的数据整帧的大小好多倍。很蹊跷,我查看了一下代码发现
  @Override
public int readableBytes() {        if (terminated) {            return buffer.readableBytes();        } else {            return Integer.MAX_VALUE - buffer.readerIndex();        }    }
 
从结果上看terminated为false,所以他返回了Integer.MAX_VALUE - buffer.readerIndex();。terminated是什么呢有什么作用呢我又查看了code,terminated仅在cleanup的时候。当terminated为true才会读到真实buffer的readableBytes和capacity。并且ReplayingDecoderBuffer为protected,只能package内部使用,我们就不能将buffer转型为该类。至于terminated的作用还是没有想明白,还是尽量别用readableBytes这个方法,绕过他去吧。

转载地址:http://cqdmi.baihongyu.com/

你可能感兴趣的文章
Net远程管理实验
查看>>
反病毒专家谈虚拟机技术 面临两大技术难题
查看>>
几种典型的反病毒技术:特征码技术、覆盖法技术等
查看>>
Software Security Testing软件安全测试
查看>>
论文浅尝 | 通过共享表示和结构化预测进行事件和事件时序关系的联合抽取
查看>>
论文浅尝 | GMNN: Graph Markov Neural Networks
查看>>
廖雪峰Python教程 学习笔记3 hello.py
查看>>
从内核看epoll的实现(基于5.9.9)
查看>>
python与正则表达式
查看>>
安装.Net Framework 4.7.2时出现“不受信任提供程序信任的根证书中终止”的解决方法
查看>>
input type=“button“与input type=“submit“的区别
查看>>
解决Github代码下载慢问题!
查看>>
1.idea中Maven创建项目及2.对idea中生命周期的理解3.pom文件夹下groupId、artifactId含义
查看>>
LeetCode-栈|双指针-42. 接雨水
查看>>
stdin,stdout,stderr详解
查看>>
Linux文件和设备编程
查看>>
文件描述符
查看>>
终端驱动程序:几个简单例子
查看>>
登录linux密码验证很慢的解决办法
查看>>
fcntl函数总结
查看>>