并发编程 | Netty - [编解码器]

INDEX

基本介绍
Netty 通过编码器将消息转换成通信数据进行传输
Netty 通过编码器将接收到的通讯数据转换成消息以使用
编解码器可能在一次 出站、入站中被多次调用,直到出入站数据不再满足编解码条件

  • Decoder

    • 继承 ChannelInboundHandlerAdapter
    • 需要实现 decode 方法
    protected abstract void decode(ChannelHandlerContext ctx, I msg, List<Object> out) throws Exception;
    
    • MessageToMessageDecoderByteToMessageDecoderReplayingDecoder<Void>
  • Encoder

    • 继承 ChannelOutboundHandlerAdapter
    • 需要实现 encode 方法
    protected abstract void encode(ChannelHandlerContext ctx, I msg, List<Object> out) throws Exception;
    
    • MessageToMessageEncoderMessageToByteEncoder
  • 编解码方法 encodedecodeChannelHandler 的读写方法中被调用

    @Override
    public void write(ChannelHandlerContext ctx, Object msg, ChannelPromise promise) throws Exception {
        CodecOutputList out = null;
        try {
            if (acceptOutboundMessage(msg)) {
                out = CodecOutputList.newInstance();
                @SuppressWarnings("unchecked")
                I cast = (I) msg;
                try {
                    encode(ctx, cast, out);
                } finally {
                    ReferenceCountUtil.release(cast);
                }
				// 略
            } else {
                ctx.write(msg, promise);
            }
        } catch (EncoderException e) {
            throw e;
        } catch (Throwable t) {
            throw new EncoderException(t);
        } finally {
            // 略
        }
    }

常见编解码器

ReplayingDecoder<S>

  • <S> 表示用户状态管理类型,Void 时表示不需要状态管理
  • 不需要调用 readableBytes() 方法
  • 缺点
    • 不能支持所有 ByteBuf 操作,如果使用了不支持的方法,会抛出 UnsupportedOperationException
    • 部分情况下效率较低,如网络缓慢且消息格式复杂时(消息会拆碎成多个片段)

LineBasedFrameDecoder

  • 基于行尾控制符 \r\r\n 作为分隔符解析数据

DelimiterBasedFrameDecoder

  • 基于自定义特殊字符作为分隔符解析数据

HttpObjectDecoder

  • Http 数据解码器

LengthFieldBasedFrameDecoder

  • 通过指定长度标识整个数据包,可以自动处理黏包、半包消息
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值