第 10 章 编解码器框架

  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());
        }
    }
    
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容