A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 不二晨 金牌黑马   /  2019-1-26 09:40  /  980 人查看  /  2 人回复  /   1 人收藏 转载请遵从CC协议 禁止商业使用本文

Java NIO与之间的普通IO的工作方式不同。标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(Buffer)进行操作。

Buffer
利用Buffer读写数据,通常遵循四个步骤:
1.把数据写入buffer;
2.调用flip;(通过flip方法把buffer从写模式调整到读模式)
3.从Buffer中读取数据;
4.调用buffer.clear()(当读取完数据后,需清空buffer,满足后续操作)

buffer缓冲区实质上就是一块内存,用于写入数据,也供后续再次读取数据。这块内存被NIO Buffer管理,并提供一系列的方法用于更简单的操作这块内存。

Buffer的三个属性:
capacity容量
position位置
limit限制

容量(Capacity)
作为一块内存,buffer有一个固定的大小,叫做capacity容量。也就是最多只能写入容量值得字节,整形等数据。一旦buffer写满了就需要清空已读数据以便下次继续写入新的数据。

位置(Position)
当写入数据到Buffer的时候需要中一个确定的位置开始,默认初始化时这个位置position为0,一旦写入了数据比如一个字节,整形数据,那么position的值就会指向数据之后的一个单元,position最大可以到capacity-1。
当从Buffer读取数据时,也需要从一个确定的位置开始。buffer从写入模式变为读取模式时,position会归零,每次读取后,position向后移动。

上限(Limit)
在写模式,limit的含义是我们所能写入的最大数据量。它等同于buffer的容量。
一旦切换到读模式,limit则代表我们所能读取的最大数据量,他的值等同于写模式下position的位置。
数据读取的上限时buffer中已有的数据,也就是limit的位置(原position所指的位置)。

Channel
Java NIO Channel通道和流非常相似,主要有以下几点区别:
通道可以读也可以写,流一般来说是单向的(只能读或者写)。
通道可以异步读写。
通道总是基于缓冲区Buffer来读写。

Selector
Selector是Java NIO中的一个组件,用于检查一个或多个NIO Channel的状态是否处于可读、可写。如此可以实现单线程管理多个channels,也就是可以管理多个网络链接。
---------------------
【转载,仅作分享,侵删】
作者:*是杯酒渐浓*
原文:https://blog.csdn.net/weixin_43560292/article/details/86435872


2 个回复

倒序浏览
奈斯
回复 使用道具 举报
nio什么东西,来学习一下
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马