• NIO流—理解Buffer、Channel概念和NIO的读写操作


    NIO流与IO流的区别

    面向流与面向块

    • IO流是每次处理一个或多个字节,效率很慢(字符流处理的也是字节,只是对字节进行编码和解码处理)。
    • NIO流是以数据块为单位来处理,缓冲区就是用于读写的数据块。缓冲区的IO操作是由底层操作系统实现的,效率很快。

    阻塞式与非阻塞式

    • IO流是阻塞式的,使用read()与write()方法时,执行期间只能等待该方法完成。
    • NIO流是非阻塞式的,执行读写时依然可以做别的事情,不会阻塞线程,提高资源利用率,NIO流的Selector就是非阻塞式的。

    NIO加入了Selector(选择器)

    • Selector可以让一个线程监视多个Channel,只需要一个线程处理所有管道,减少线程开销。

    nio流的相关类都放在java.nio包中,大体如下:

    • java.nio 包:包含各种类型的Buffer(缓冲区)
    • java.nio.channels包:包含各种Channel(管道) 和Selector(选择器)
    • java.nio.charset包:包含各种处理字符集的类

    Buffer(缓冲区)

    • 常用ByteBuffer 和 CharBuffer,还有一系列值类型Buffer,可以应用于不同类型。
    • 所有Buffer都是抽象类,无法直接实例化。创建缓冲区要调用XxxBuffer allocate(),参数是缓冲区容量
    • 缓冲区数据存放在内存中,读写效率高。缓冲区有记录指针,能改变读写的起始点,根据不同需求,灵活处理数据。
    Buffer参数说明
    • capacity(容量):缓冲区支持的最大容量。
    • position(记录指针位置):是缓冲区读写数据的起始点,初始值为0。position随着数据的加入而改变,例如读取2个数据到Buffer中,则position = 2。
    • limit(界限):是缓冲区读写数据的终止点,limit之后的区域无法访问。
    • mark(标记):mark在0~position之间,设置该值就会把position移动到mark处。
    Buffer的常用方法:
    • flip():确定缓冲区数据的起始点和终止点,为输出数据做准备(即写入通道)。此时:limit = position,position = 0。
    • clear():缓冲区初始化,准备再次接收新数据到缓冲区。position = 0,limit = capacity。
    • hasRemaining():判断postion到limit之间是否还有元素。
    • rewind():postion设为0,则mark值无效。
    • limit(int newLt):设置界限值,并返回一个缓冲区,该缓冲区的界限和limit()设置的一样。
    • get()和put():获取元素和存放元素。使用clear()之后,无法直接使用get()获取元素,需要使用get(int index)根据索引值来获取相应元素。
    图片理解Buffer读写数据的流程变化

  • 相关阅读:
    干货分享|一些好的数据分析、数据挖掘的网站或数据学习网站
    Oracle-多表查询
    Linux 系统执行ls 命令出现 Input/output error 解决妙招
    【MATLAB教程案例45】基于双目视觉的图像深度信息提取算法matlab仿真
    高密分子定位技术
    java毕业设计大学生过程培养信息系统Mybatis+系统+数据库+调试部署
    ML/DL2022面试必备500知识点-《机器和深度学习纲要》免费分享
    1688阿里巴巴官方api数据接口采集店铺的所有商品详情店铺管理接入演示案例
    harbor v1.7.1镜像仓库无法访问,并提示502 Bad Gateway
    从零入手人工智能(2)——搭建开发环境
  • 原文地址:https://blog.csdn.net/m0_73533108/article/details/126930762