NioServerSocketChannel

NioServerSocketChannel

        • 回顾前言
        • 执行NioServerSocketChannel构造函数
        • NioServerSocketChannel构造函实现
      • AbstractNioMessageChannel
        • 构造函数
      • AbstractNioChannel
        • 构造函数
      • AbstractChannel
        • 构造函数
      • NioServerSocketChannelConfig
      • DefaultServerSocketChannelConfig
        • 构造函数
      • DefaultChannelConfig
        • 构造函数
          • doReadMessages
            • NIO accept
      • doBind Channel通过基本的通信组件建立连接
      • doReadMessages
        • buf.add(new NioSocketChannel(this, ch));

在这里插入图片描述

回顾前言

在这里插入图片描述

在netty Bootstrap启动之后会执行 channel,此时将NioServerSocketChannel的Class对象加入到BootStrap 的ChannelFactory之中,这个ChannelFactory是ReflectiveChannelFactory类型的

在这里插入图片描述
在这里插入图片描述
但是什么时候真正使用该Channel呢?
在这里插入图片描述
在这里插入图片描述
这里调用Class.newInstance()会跳到该类的构造函数
在这里插入图片描述

执行NioServerSocketChannel构造函数

可以看出先创建一个ServerSocketChannelImpl对象,然后以该对象作为入参执行NioServerSocketChannel的构造函数
在这里插入图片描述

在这里插入图片描述
首先执行 newSocket方法
在这里插入图片描述
熟悉NIO的话就明白了,ServerSocketChannelImpl是NIO最基本的组件,可见Netty是对NIo的进一步优化和封装。
在这里插入图片描述

然后再以ServerSocketChannelImpl为入参执行构造方法构造NioServerSocketChannel

NioServerSocketChannel构造函实现

NioServerSocketChannel

跳转到父类AbstractNioMessageChannel构造函数

AbstractNioMessageChannel

在这里插入图片描述

构造函数

在这里插入图片描述

AbstractNioChannel

在这里插入图片描述

构造函数
设置非阻塞

在这里插入图片描述

AbstractChannel

在这里插入图片描述

构造函数

两个重要组件在这里初次登场
DefaultChannelId和DefaultChannelPipeline,还有比较重要的Unsafe

在这里插入图片描述

在这里插入图片描述
DefaultChannelId
在这里插入图片描述
DefaultChannelPipeline

NioServerSocketChannelConfig

在这里插入图片描述

在这里插入图片描述

DefaultServerSocketChannelConfig

在这里插入图片描述

构造函数

在这里插入图片描述

DefaultChannelConfig

在这里插入图片描述

构造函数

在这里插入图片描述
在这里插入图片描述

doReadMessages

在这里插入图片描述

NIO accept
  public SocketChannel accept() throws IOException {synchronized(this.lock) {if (!this.isOpen()) {throw new ClosedChannelException();} else if (!this.isBound()) {throw new NotYetBoundException();} else {SocketChannelImpl var2 = null;int var3 = 0;FileDescriptor var4 = new FileDescriptor();InetSocketAddress[] var5 = new InetSocketAddress[1];InetSocketAddress var6;try {this.begin();if (!this.isOpen()) {var6 = null;return var6;}this.thread = NativeThread.current();do {var3 = this.accept(this.fd, var4, var5);} while(var3 == -3 && this.isOpen());} finally {this.thread = 0L;this.end(var3 > 0);assert IOStatus.check(var3);}if (var3 < 1) {return null;} else {IOUtil.configureBlocking(var4, true);var6 = var5[0];var2 = new SocketChannelImpl(this.provider(), var4, var6);SecurityManager var7 = System.getSecurityManager();if (var7 != null) {try {var7.checkAccept(var6.getAddress().getHostAddress(), var6.getPort());} catch (SecurityException var13) {var2.close();throw var13;}}return var2;}}}}

doBind Channel通过基本的通信组件建立连接

在这里插入图片描述
javaChannel其实就是我们Nio中的ServerSocketChannelImpl

接下来就是NIO实现了
在这里插入图片描述

在这里插入图片描述

doReadMessages

    protected int doReadMessages(List<Object> buf) throws Exception {SocketChannel ch = this.javaChannel().accept();try {if (ch != null) {buf.add(new NioSocketChannel(this, ch));return 1;}} catch (Throwable var6) {logger.warn("Failed to create a new channel from an accepted socket.", var6);try {ch.close();} catch (Throwable var5) {logger.warn("Failed to close a socket.", var5);}}return
buf.add(new NioSocketChannel(this, ch));


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部