NIO原理

网络体系:
OSI IEEE
IO体系
本地(local)IO
字节流:InputStream、OutputStream
字符流:Reader、Writer
网络(远程)IO

NIO与IO区别:

在这里插入图片描述

NIO通道和缓冲区:

通道(Channel):表示打开IO设备(例如:文件、套接字Socket)的连接。若需要NIO系统,需要获取用于连接IO设备的通道以及用于容纳数据的缓冲区(Buffer)。然后操作缓冲区,对数据进行处理。
缓冲区(Buffer):一个用于特定基本数据类型的容器。由java.nio包定义的,所有缓冲区都是Buffer抽象类的子类。Java NIO中的Buffer主要用于与NIO通道进行交互,数据是从通道读入缓冲区,从缓冲区写入通道中。
简单说:Channel负责传输,Buffer负责存储

缓冲区:

  1. 在java NIO中负责数据的存储。缓冲区就是数组。用于存储不同数据类型的数据。
    根据数据类型不同,提供相应的数据类型的缓冲区:
    ByteBuffer、CharBuffer、ShortBuffer、IntBuffer、LongBuffer、FloatBuffer、DoubleBuffer、
    上述缓冲区管理方式几乎一致,通过allocate() 获取缓冲区

  2. 缓冲区存储数据的两个核心方法:
    put() :存入数据到缓冲区中
    get() :获取缓冲区中的数据

  3. 缓冲区的四个核心属性
    capacity:容量,表示缓冲区中最大存储数据的容量。一旦声明不能改变。
    limit:界限,表示缓冲区中可以操作数据的大小。(limit后数据不能进行读写)
    position:位置,表示缓冲区中正在操作数据的位置。
    mark : 标记,表示记录当前position的位置。可以通过reset() 恢复到mark的位置。
    0 <= mark <= position <= limit <= capacity
    API:
    allocate : 分配一个指定大小的缓冲区
    put : 存入数据到缓冲区
    get : 读取缓冲区中数据
    flip : 切换读取数据模式
    rewind : 可重复读数据
    clear : 清空缓冲区,回到最初状态,但是实际上,数据并没有被清空,缓冲区数据依然存在,处于被遗忘状态,四个核心属性重置了。
    reset :恢复到mark的位置
    mark :标记,表示记录当前position的位置。可以通过reset() 恢复到mark的位置。
    hasRemaining :判断缓冲区还有没有可以操作的数据
    remaining : 获取缓冲区中可操作的数量

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

erainm

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值