Channel分类
在Netty中存在众多Channel类和接口,大致关系如下:
Netty中Channel类图
- Channel:和Java Nio中的Channel同名,是Netty对网络底层读写和连接的抽象。
- AbstractChannel: 是Channel的抽象实现类,抽象出了parent,id,unsafe,pipeline等概念。
- AbstractNioChannel:封装Java NIO,通过Selector选择器进行IO事件的监听,拥有SelectionKey,readInterestOp等NIO的属性,这是在这个类的构造函数中设置了非阻塞模式。
- AbstractNioByteChannel此抽象类开始的分支中的类都是关于客户端的Channel,AbstractNioMessageChannel此抽象类开始的分支中的类都是关于服务端的Channel,前者和后者都继承自AbstractNioChannel,区别在于客户端Channel注册的感兴趣的事件时READ事件,服务端Channel注册的感兴趣的事件时ACCEPT事件。
- NioByteUnsafe类是客户端实现读写的类,NioMessageUnsafe类是服务端实现读写的类,二者的区别在于读写的具体实现不同。
-
客户端与NioSocketChannel关联的配置类为NioSocketChannelConfig类,服务端与NioServerSocketChannel关联的配置类为NioServerSocketChannelConfig类。下面也列了下配置类的类图:
配置类图
作者:云师兄
链接:https://www.jianshu.com/p/f654f66d8572
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。