zoukankan      html  css  js  c++  java
  • 221 netty模型相关

    0、一些代码内容ServerBootstrap(group、channel) EventLoopGroup ChannelFuture

    1、 reactor模型相关实现:

      客户端请求-->reactor线程(eventloopselector做事件轮训-->dispatcher分发)  --->处理方法

    netty启动时会构建多个EventloopGroup(reactor线程)

    2、pipeline 责任链相关

       责任链: 可以认为是责任递进的链条(集合形式、链表形式)。包含:处理器抽象类、处理器实现、保存处理器信息(下个节点)、处理执行

        registered入栈时间处理:bind端口abstractBootStrap--》创建和初始化channel--》注册eventLoop到selector上(config group register后 触发channel注册) ps 初始化handler仅执行一次

                                                 注册完成后 省下 headcontext loggingHandler ServerBootstrapAcceptor  tailcontext

       bind 出站事件处理 bind(端口):abstractBootstrap  ->创建和初始化channel -> 注册到eventloop的selector上 ->channelbind -> pipelinebind

       accept入栈事件的处理:Eventloop轮询到accept事件-》nioMessageUnsafe.read

    3、bytebuf

         容量(可以动态扩容)、读取位置、写入位置----已读取区域,可读取区域、待写区域

         实现方式:堆内堆外、是否池化、访问方式(safe,unsafe)

  • 相关阅读:
    poj3107 Godfather
    poj1655 Balancing Act
    bzoj2073 PRZ
    bzoj1688 疾病管理
    BZOJ——1607: [Usaco2008 Dec]Patting Heads 轻拍牛头
    BZOJ——1606: [Usaco2008 Dec]Hay For Sale 购买干草
    BZOJ——1649: [Usaco2006 Dec]Cow Roller Coaster
    BZOJ——2096: [Poi2010]Pilots
    洛谷—— P1785 漂亮的绝杀
    NOIP 2012 提高组 DAY1 T2 国王游戏
  • 原文地址:https://www.cnblogs.com/windghost/p/13163907.html
Copyright © 2011-2022 走看看