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

  • 相关阅读:
    windows本地文件搜索神器 Everything 为什么速度这么快?
    Electron构建跨平台应用
    「前端进阶」高性能渲染十万条数据(虚拟列表)
    Chrome开发者工具之JavaScript内存分析
    网页性能管理详解
    TCP-IP详解:滑动窗口(Sliding Window)
    滑动窗口
    流量控制(滑动窗口)和 拥塞控制(拥塞控制的工作过程)
    详解 Git 大文件存储(Git LFS)
    TCP流量控制
  • 原文地址:https://www.cnblogs.com/lxyit/p/9141120.html
Copyright © 2011-2022 走看看