Netty进阶学习(六):Netty#initAndRegister#register()理解

╰+攻爆jí腚メ 2023-07-03 02:58 64阅读 0赞
背景
  1. 究竟是哪个线程执行了doRegister()方法?
  2. Channel实例是谁?
  3. Selector实例是谁?又怎么绑定到NioEventLoop上的?

过程

  1. EventLoop执行register0()#doRegister()方法
    在这里插入图片描述
    启动的时候是main主线程,并不是EventLoop线程。然后new一个任务的方式丢到EventLoop中,它是放到队列中的,然后启动线程。这个时候才会去 Queue中拿到task并且执行。然后执行我们的doRegister()方法的。
  2. javaChannel().register(eventLoop().unwrappedSelector(), 0, this),这里的this非常重要,是Attachment类型。实际传递的是NioServerSocketChannel实例。
    在这里插入图片描述
    javaChannel()是当前channel(实际上是JDK的SelectableChannel的实例),eventLoop实例中有Selector(JDK中的Selector)的引用,带来的attachment内容就是NioServerSocketChannel实例,当事件发生的时候,需要对事件进行处理,这个时候需要拿到NioServerSocketChannel。

    NioEventLoop上会绑定一个Selector,是怎么绑定的?这个NioEventLoop类就持有NIO相关组件如Selector和SelectedSelectionKeySet。创建NioEventLoopGroup实例的时候,底层代码就会创建Selector实例,并赋值给NioEventLoop实例的Selector属性。

小结

  1. 因为注册过程是NIO底层的执行逻辑。
  2. 辅助阅读。
    Java NIO的Selector核心类图及其执行逻辑分析
    Java NIO的Selector、Channel、Buffer相互之间的关系

发表评论

表情:
评论列表 (有 0 条评论,64人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Netty 学习策略

    > 《Netty 进阶之路》、《分布式服务框架原理与实践》作者李林锋手把手教你Netty框架如何学习和进阶。李林锋此后还将在InfoQ上开设Netty专题持续出稿,感兴趣的同学

    相关 Netty和实战

    实现UDP单播和广播 UDP 这样的无连接协议中,并没有持久化连接这样的概念,并且每个消息(一个UDP 数据报)都是一个单独的传输单元。此外,UDP 也没有TCP 的纠错