• 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部分能够有个全局性的认识。后续会详细介绍第四层通道的用途及用法。

  • 相关阅读:
    用Jquery控制文本框只能输入数字和字母
    Math:弧度制
    python学习之案例
    python自动化模块之实践一
    python学习之路 第六天
    python学习之路 第五天
    python学习之路 第四天
    python学习之路 第三天
    python学习之路 第二天
    python学习之路 第一天
  • 原文地址:https://www.cnblogs.com/lxyit/p/9141120.html
Copyright © 2020-2023  润新知