Channel延续篇

Posted 怀瑾握瑜

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Channel延续篇相关的知识,希望对你有一定的参考价值。

上篇文章中介绍了NIO中的Channel,从Channel是什么、特性、分类几个方面做了下简单的介绍。但是后面Channel的分类,个人感觉不够全面,容易误导读者,特此以这篇文章加以补充。

Channel概览

这里我们直奔主题,先通过概览性的UML类图总体直观性的感受下Channel

接下来分析下这个UML图。从层次,具体的接口和实现类方面介绍。

一.层次

对于NIO的Channel的模块,Java的设计者们还是用心良苦。层次突出,接口行为的划分精细,职责单一而清晰。

从图中不难看出,Channel主要被分为四层:

  1. Channel顶层接口
  2. 根据不同能力划分通道:可读通道、可写通道、网络型通道、异步、可中断
  3. 基于以上的读写和网络上的能力继续进行分层:聚集(write的内聚)、分散(read的拆分)、可选择性(用于Selector多路复用)
  4. 各种具体用途的Channel的实现

二.接口和实现

1.第一层
  • Channel:作为NIO中通道的最顶层接口,抽象的定义描述了通道的概念,通道可以打开可以关闭的行为
2.第二层
  • ReadableByteChannel:代表具有读能力的通道,描述了通道的可读行为,只要具有可读能力的通道都应该实现它
  • WriteableByteChannel:代表具有写能力的通道,描述了通道的可写行为,只要具有可写能力的通道都应该实现它
  • NetworkChannel:代表网络类型的通道,只要连接到Socket套接字,都需要实现它
  • AsynchronousChannel:代表具有异步I/O操作能力的通道,只是定义了通道异步关闭的行为,具有异步读写能力的通道都应该实现它
  • InterruptibleChannel:代表可中断式通道,即一个线程阻塞在该通道的I/O上,另一个线程可以关闭通道中断阻塞在该通道上的线程
3.第三层
  • SeekableByteChannel:可查找的通道,内部维护位置position,通过位置的切换,实现自由读写
  • ScatteringByteChannel:具有分散能力的通道,即从通道中读取数据至多个Buffer缓冲区的能力
  • GatheringByteChannel:具有聚集能力的通道,即从多个顺序的Buffer缓冲区中写数据至通道的能力
4.第四层

该层就是具有实际能力的通道,直接与Java应用开发者相关的,应用中直接使用的API。

这里就不再赘述,可移步至我的上篇文章Channel概述,该篇博文中介绍了第四层的相关用途的通道。

本文主要就是为了补充上篇文章,让读者能够对NIO中Channel部分能够有个全局性的认识。后续会详细介绍第四层通道的用途及用法。

以上是关于Channel延续篇的主要内容,如果未能解决你的问题,请参考以下文章

Netty进阶篇3:Channel到底干了些什么?

go语音之进阶篇无缓冲channel

Netty4 Channel 概述(通道篇)

GO (channel简单使用篇)

Golang 高效实践之并发实践context篇

自动驾驶 Apollo 源码分析系列,系统监控篇:Monitor模块如何监控通信中 channel 的时延?