美文网首页
第 10 章 编解码器框架

第 10 章 编解码器框架

作者: FaDeo_O | 来源:发表于2017-12-20 21:16 被阅读0次
  1. 解码器用于将入站数据从一种格式转换到另一种格式,主要包括两类
    • 将字节解码为消息——ByteToMessageDecoderReplayingDecoder
    • 将一种消息类型解码为另一种——MessageToMessageDecoder
  2. ReferenceCountUtil.retain(message)可以增加消息的引用计数,以便稍后使用
  3. 通过使用ReplayingDecoder可不必检测可读的数据量,它通过使用一个自定义的ByteBuf实现,ReplayingDecoderByteBuf,包装传入的ByteBuf实现了这一点,其将在内部执行该调用,ReplayingDecoder 稍慢于ByteToMessageDecoder
  4. 准则:如果使用ByteToMessageDecoder不会引入太多的复杂性,那么请使用它;否则,请使用 ReplayingDecoder
  5. Netty 提供了TooLongFrameException类,其将由解码器在帧超出指定的大小限制时抛出
  6. 编码器实现了ChannelOutboundHandler,并将出站数据从一种格式转换为另一种格式
    • 将消息编码为字节——MessageToByteEncoder
    • 将消息编码为消息——MessageToMessageEncoder
  7. 抽象编解码器捆绑一个解码器/编码器对,如ByteToMessageCodec结合了
    ByteToMessageDecoder以及它的逆向——MessageToByteEncoderMessageToMessageCodec<INBOUND_IN,OUTBOUND_IN>可实现两种类型的往返转换过程
  8. CombinedChannelDuplexHandler<I extends ChannelInboundHandler,O extends ChannelOutboundHandler>可实现一个编解码器
    public class CombinedByteCharCodec extends CombinedChannelDuplexHandler<ByteToCharDecoder, CharToByteEncoder> {
        public CombinedByteCharCodec() {
            super(new ByteToCharDecoder(), new CharToByteEncoder());
        }
    }
    

相关文章

网友评论

      本文标题: 第 10 章 编解码器框架

      本文链接:https://www.haomeiwen.com/subject/yoltwxtx.html