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操作

相关推荐
qq_12498707539 分钟前
基于springboot的兴趣生活展示交流平台的设计与实现(源码+论文+部署+安装)
java·spring boot·生活·毕设
2501_9411115214 分钟前
C++中的适配器模式
开发语言·c++·算法
2501_9411119415 分钟前
C++中的适配器模式变体
开发语言·c++·算法
明洞日记16 分钟前
【设计模式手册008】适配器模式 - 让不兼容的接口协同工作
java·设计模式·适配器模式
zzz海羊16 分钟前
VSCode配置java中的lombok
java·开发语言·vscode
A-code21 分钟前
Git 多模块项目管理
java·开发语言
TDengine (老段)23 分钟前
TDengine 字符串函数 Replace 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
没头脑的男大28 分钟前
Unet实现脑肿瘤分割检测
开发语言·javascript·ecmascript
java_logo30 分钟前
BUSYBOX Docker 容器化部署指南
java·运维·python·nginx·docker·容器·运维开发
2501_9411117739 分钟前
C++代码移植性设计
开发语言·c++·算法