Java NIO和AIO的一些见解

一、NIO的缓冲翻转

ByteBuffer在经过read()写入数据后,需要调用flip()方法翻转,才能被读取,调用SocketChannel的write()方法输出。

二、NIO的Selector的阻塞选择和唤醒

1、有select()方法来阻塞选择。

2、select(超时时间) 可以在规定时间内返回。

超时就抛出异常。

3、唤醒和退出

如果阻塞在select()方法,或者更新Channel的事件注册,需要调用wakeup()方法,来立即返回select()方法。

唤醒后就能判断最新的事件,就能判断循环退出的标志变量。

while(isRun){

if(selector.select() > 0){

// 处理通道满足的事件

}

}

三、NIO如何确定事件注册时机

以HTTP协议的服务端为案例:

1、服务端注册Accept事件。

2、处理Accept连接事件时,注册Read读取事件。

3、处理Read事件时,先取消Read注册,然后分多次读取HTTP的请求行、请求头、请求体,封装成请求对象。

同时判断URL对应的逻辑,添加Write事件。

4、处理Write事件时,先取消Write注册,然后把头部输出,把响应体输出。

短链接就可以是直接关闭连接。

如果是长连接,可能无法确定写入顺序;需要队列来确定输出任务的顺序。

每次处理事件时,需要先把事件注册取消;等本次处理完毕后,再根据需要添加下回的事件注册。

四、AIO的异步调用怎么设置顺序

1、用AIO来异步读取协议数据包的每个部分,可能需要分多次读取。

2、用AIO来异步输出协议数据包的头部和负载数据,可能需要2次以上调用。

3、如何控制调用顺序?

第一种、把每个任务按顺序放入队列里。

每次调用就获取一个任务,等任务调用完成后,才获取下一个任务。

第二种、当前任务调用完成后,传入新的参数,再递归调用自己,添加监听事件。

相关推荐
JackSparrow4145 天前
彻底理解Java NIO(二)C语言实现 I/O多路复用+Reactor模式 服务器详解
java·linux·c语言·后端·nio·reactor模式
xu_ws11 天前
redis的io多路复用和Java NIO的区别
java·redis·nio
苍煜12 天前
Java开发IO零基础吃透:BIO、NIO、同步异步、阻塞非阻塞
java·python·nio
身如柳絮随风扬25 天前
深入理解Java IO与NIO的区别:从BIO到NIO的演进
java·nio
白晨并不是很能熬夜25 天前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
笨手笨脚の1 个月前
详解五种IO模型
nio·bio·aio·io模型
JackSparrow4141 个月前
彻底理解Java NIO(一)C语言实现 单进程+多进程+多线程 阻塞式I/O 服务器详解
java·linux·c语言·网络·后端·tcp/ip·nio
杨凯凡1 个月前
【019】IO/NIO 概念:Web 开发要掌握到什么程度
java·开发语言·nio
佛祖让我来巡山1 个月前
Netty入门|从BIO到Netty:一步步看懂Java网络编程的迭代逻辑
netty·nio·bio
devilnumber1 个月前
java的NIO框架Netty、Mina、Grizzly 和 Jetty 四种对比
java·nio·java面试·jetty