美文网首页深入浅出Netty源码剖析Java 杂谈
【第22篇】Netty解码器剖析与入站出站处理器

【第22篇】Netty解码器剖析与入站出站处理器

作者: 爱学习的蹭蹭 | 来源:发表于2019-06-03 11:47 被阅读2次

    Netty的处理器重要概念

    • 1、Netty的处理器可以分为两大类:入站处理器与出站处理器
    • 2、入站处理器的顶层是ChannelInboundHandler,而出站处理器的顶层是ChannelOutboundHandler
    • 3、数据处理器时常用的各种编解码,本质上都是处理器
    • 4、编解码器:物流我们向网络希尔的数据是什么类型(int,char,String 二进制等)数据在网络传递时候,其都是以字节流的形式呈现的,将数据由原本的形式转换为字节流的操作成为编码encode,将数据由字节流转换成原本的格式或是其他格式的操作称为解码(decode),编解码统称为codec
    • 5、编码:本质上是一种出站的处理器,因此一定是ChannelOutboundHandler
    • 6、解码:本质上是一种入站的处理器,因此一定是ChannelInboundHandler
    • 7、在Netty中,编码器通常以XXXEncoder命名,解码器通常以XXXDecoder命名
      *入站处理器代码使用如:
    public class MyServerHandler extends SimpleChannelInboundHandler<String> {
    
        @Override
        protected void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception {
            System.out.println(ctx.channel().remoteAddress() + ", " + msg);
            ctx.channel().writeAndFlush("from server: " + UUID.randomUUID());
        }
    
        @Override
        public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
            cause.printStackTrace();
            ctx.close();
        }
    }
    
    SimpleChannelInboundHandler ChannelInboundHandler ChannelOutboundHandler

    关于Netty编解码的重要结论

    • 1、无论是编码器还是解码器,其所接收的消息类型,必须要与待处理的参数类型一致,否则该编码器或解码器并不会被执行
    • 2、在解码器进行数据解码时候,一定要记得判断(ByteBuf)中的数据是否足够,否则将会产生一些问题

    组合方式管理通道句柄

    • CombinedChannelDuplexHandler,从代码里面看出来,它基础ChannelDuplexHandler管道,此类有诸多重要的方法如:bind,channelRead,
      connectdisconnectderegister,而它有一个内部类DelegatingChannelHandlerContext,它也有比较多重要的方法,如:alloc,attr,bind这里不写了,请看【DelegatingChannelHandlerContext方法】截图
    CombinedChannelDuplexHandler关系图

    DelegatingChannelHandlerContext方法

    DelegatingChannelHandlerContext方法

    相关文章

      网友评论

        本文标题:【第22篇】Netty解码器剖析与入站出站处理器

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