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

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类。下面也列了下配置类的类图:


    配置类图
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Netty的简单介绍 Netty 是一个 NIO client-server(客户端服务器)框架,使用 Netty...
    AI乔治阅读 12,666评论 1 101
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,060评论 19 139
  • 儿子从小到大就是跌跌撞撞,经常头顶撞出一个个的大包,我们这边叫头上起的大包叫瘤,其发音与“楼”一样,儿子爷爷笑称儿...
    风铃_12bf阅读 1,310评论 0 0
  • 2017年圣诞前夕,于武功山与一群于网上结识的朋友完成了两天一夜的徒步反穿。从出发到结束,从上山到下山,在整个徒步...
    懒夏的鱼阅读 5,675评论 7 6
  • 我目睹了一场离去 离去与死亡走的很近 像是最后一宿秋风 将你的小船掀翻 岸距你的呼喊 依然遥远 我踩住一片叶子 顿...
    道夫123阅读 1,580评论 5 26

友情链接更多精彩内容