Netty 解码器-ReplayingDecoder

ReplayingDecoder是Netty中的一个解码器,它扩展了ByteToMessageDecoder并处理了数据读取的判断。用户可以指定状态管理类型S,Void表示无需状态管理。在ReplayByteToLongDecoder示例中,它直接读取并转换ByteBuf为长整型。然而,ReplayingDecoder不支持所有ByteBuf操作,且在网络延迟高、消息分片复杂时可能性能稍慢。其他替代解码器如LineBasedFrameDecoder、DelimiterBasedFrameDecoder、HttpObjectDecoder和LengthFieldBasedFrameDecoder分别用于不同场景的数据解析。
public abstract class ReplayingDecoder<S> extends ByteToMessageDecoder

ReplayingDecoder 扩展了 ByteToMessageDecoder 类, 使用这个类,我们不必调用 readableBytes() 方法。 参数 S 指定了用户状态管理类型,其中 Void 代表不需要状态

ReplayByteToLongDecoder:
import io.netty.buffer.ByteBuf;
import io.netty.channel.ChannelHandlerContext;
import io.netty.handler.codec.ReplayingDecoder;

import java.util.List;

public class ReplayByteToLongDecoder extends ReplayingDecoder<Void> {
    @Override
    protected void decode(ChannelHandlerContext channelHandlerContext, ByteBuf byteBuf, List<Object> list) throws Exception {
        System.out.println("ReplayByteToLongDecoder 被调用");
        // 在 replayingDecoder 不需要判断数据是否足够读取,内部会进行处理判断
        list.add(byteBuf.readLong());
    }
}

局限性:

  • 并不是所有的 ByteBuf 操作都被支持,如果调用了一个不被支持的方法,将会抛出一个 UnsupportedOperationException。
  • ReplayingDecoder 在某些情况下可能稍慢于 ByteToMessageDecoder, 例如网络缓慢并且消息格式复杂,消息会被拆分了多个碎片,速度变慢

其他编码器:

  • LineBasedFrameDecoder: 这个类在Netty内部也有使用,它使用行尾控制字符(\n 或者 \r\n) 作为分隔符来解析数据
  • DelimiterBasedFrameDecoder: 使用自定义的特殊字符作为消息的分隔符
  • HttpObjectDecoder: 一个 Http 数据的解码器
  • LengthFieldBasedFrameDecoder: 通过执行长度标识整包消息,这样就可以自动的处理黏包和半包消息
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值