Java NIO操作

NIO是相对于blocking IO来说的,New-blocking I/O也就是NIO。是升级的IO而不是非阻塞IO。

NIO针对IO而进行的改进,所以是基于原IO设计的。

NIO的核心是下面三部分:

Channel通道,Buffer缓存区,Selector选择器

先说说他们之间是如何配合的。

运行机制

程序直接和缓存对象buffer进行数据交互。这样对于程序来说非常方便操作。

每个buffer需要接通一个channel,channel的另一边是底层目标,例如文件或者socket之类的。

每个线程有一个selector,用于自动管理channel,检查channel状态,切换不同的channel执行数据交换工作。

所以channel只在底层和buffer直接做数据交换媒介,每个channel都有一个buffer,buffer和程序直接打交道,selector在channel阻塞时切换channel执行另外的任务,这就是NIO的运行机制。

Buffer操作

buffer主要有这几个方法:

clear清空或者叫做初始化buffer

put和get或者array来操作内容

flipc切换buffer写读模式(容易忘记使用)

static allocate分配一个buffer

Channel操作

read和write操作

相关推荐
三两肉1 小时前
Java 中 ArrayList、Vector、LinkedList 的核心区别与应用场景
java·开发语言·list·集合
clk66073 小时前
SSM 框架核心知识详解(Spring + SpringMVC + MyBatis)
java·spring·mybatis
Humbunklung4 小时前
Rust 控制流
开发语言·算法·rust
ghost1434 小时前
C#学习第27天:时间和日期的处理
开发语言·学习·c#
jason成都4 小时前
c#压缩与解压缩-SharpCompress
开发语言·c#
shangjg35 小时前
Kafka 的 ISR 机制深度解析:保障数据可靠性的核心防线
java·后端·kafka
傻啦嘿哟5 小时前
从零开始:用Tkinter打造你的第一个Python桌面应用
开发语言·c#
三十一6145 小时前
6.4 C++作业
开发语言·c++
我的golang之路果然有问题6 小时前
ElasticSearch+Gin+Gorm简单示例
大数据·开发语言·后端·elasticsearch·搜索引擎·golang·gin
Alan3166 小时前
Qt 中,设置事件过滤器(Event Filter)的方式
java·开发语言·数据库