Netty学习笔记(二)Channel的分类

Channel分类

在Netty中存在众多Channel类和接口,大致关系如下:


Netty学习笔记(二)Channel的分类_第1张图片
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类。下面也列了下配置类的类图:


    Netty学习笔记(二)Channel的分类_第2张图片
    配置类图

你可能感兴趣的:(Netty学习笔记(二)Channel的分类)