Netty ByteBuf 按位读操作

36 篇文章 1 订阅

前言

        最近与一个刚接触Netty的学生关于Netty读字节流方面的操作进行讲解,可能对后来同学有点点帮助,所以整理出来供大家探讨。

ByteBuf读操作

       ByteBuf读操作我们常用的有一下几种:

       ByteBuf.readByte() 读一个字节,有符号

       ByteBuf.readUnsignedByte() 读一个字节,无符号

       ByteBuf.readShort() 读连续的两个字节,有符号

       ByteBuf.readUnsignedShort() 读连续的两个字节,无符号

       ByteBuf.readInt() 读连续的四个字节,有符号

       ByteBuf.readUnsignedInt() 读连续的四个字节,无符号

       关于有符号与无符号的区别,以ByteBuf.readByte()和ByteBuf.readUnsignedByte()为例:

       ByteBuf.readUnsignedByte()就等价于:ByteBuf.readByte()&0xFF

在做byte -> int类型转换时,JVM会做一个补位处理,
(注:补位是补1还是补0,取决于byte的最高位是1还是0)
以协议中出现的0x8A的协议号为例,转成二进制为:10001010,
如果直接赋值int值后是其实在计算机存储的是11111111 11111111 11111111 10001010(32位),
这个时候其实与最初的0x8A已经完全不等了,所以我们需要对其进行与0xFF做与运算,
可以将高24位置为0,低8位保持不变,这样做就可以保证和二进制补码的一致了。

        除了以上说的,如果我们需要N个连续的字节,可以使用:

        byte[] arr=new byte[N];
        ByteBuf.readBytes(arr);

        如果我们想读取3个字节的整型数值,可以使用:

int value=ByteBuf.readUnsignedShort()<<8+ByteBuf.readUnsignedByte();

        依次类推,读5个字节,6个字节,7个字节,8个字节都可以这样先按上述的几个方法读取连续几位,再移位,再读取后面连续的几位,并相加。

        如果想获取某个bit位是1还是0,可以用一下方法:

    public static int getBitValue(long number, int index) {
        return (number & (1 << index)) > 0 ? 1 : 0;
    }

        也可以采用先移位,再&0x01。

  • 2
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大鱼>

一分也是爱

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值