Java提供了哪些IO方式❓NIO如何实现多路复用❓

I/O 方式🍑

1)同步阻塞 I/O( BIO )✨

  • 定义与特点:在BIO模型中,当一个线程执行I/O操作如读写数据时,该线程会被阻塞,直到I/O操作完成。这意味着在I/O操作进行期间,该线程不能执行其他任务。
  • 实现:主要通过java.io包实现,如使用FileInputStream和FileOutputStream进行文件操作,或者使用Socket进行网络操作时,都是采用同步阻塞的方式。

2)同步非阻塞I/O(NIO)✨

  • 定义与特点:NIO 允许一个线程从多个通道(Channel)读写数据,通过使用选择器(Selector)实现多路复用。这种方式下,线程可以在等待某个通道准备好进行 I/O 操作时,同时检查其他通道的就绪状态,而不是阻塞在单个 I/O 操作上。
  • 实现:通过 java.nio 包实现,核心概念包括通道(Channel)、缓冲区(Buffer)、选择器(Selector)等。Selector 可以监控多个通道的 I/O 状态(如读、写就绪),实现了同步非阻塞 I/O。
  • 多路复用实现:通过 Selector,一个单独的线程可以管理多个通道,当通道准备好进行 I/O 操作时,Selector 能够检测到并允许线程处理这些事件。应用程序通过注册通道到 Selector 并指定感兴趣的事件(如读、写),Selector 轮询注册的通道,当通道就绪时,线程即可处理这些事件,实现了高效的多路复用。

3)异步非阻塞I/O(AIO/NIO.2)✨

  • 定义与特点:AIO 引入了真正的异步非阻塞 I/O 操作,应用程序可以直接返回,不需要等待 I/O 操作完成。I/O 操作完成后,系统会自动通知应用程序,应用程序再进行相应的处理。
  • 实现:通过java.nio.channels包下的异步通道(如 AsynchronousFileChannel、AsynchronousSocketChannel)实现。AIO 提供了基于事件和回调机制的 I/O 操作,极大提高了程序的性能和响应速度。

NIO如何实现多路复用❓

1)创建一个 Selector 实例🐾

Selector 是一个多路复用器,可以监控多个通道的 I/O 事件(如连接请求、数据到达等)。
Selectorselector= Selector.open();

2)配置非阻塞模式🍑

channel.configureBlocking(false);

3)注册通道到 Selector 🚆

channel.register(selector, SelectionKey.OP_READ);

4)选择就绪的通道🍒

int readyChannels= selector.select();

5)处理就绪的事件🚀

java 复制代码
Set<SelectionKey> selectedKeys = selector.selectedKeys(); 
Iterator<SelectionKey> keyIterator = selectedKeys.iterator(); 
while(keyIterator.hasNext()) { 
	SelectionKeykey= keyIterator.next(); 
	if(key.isAcceptable()) { // 处理接受事件 } 
	elseif (key.isReadable()) { // 处理读事件} 
	keyIterator.remove(); 
}
相关推荐
2401_840192271 分钟前
如何学习一门计算机技术
开发语言·git·python·devops
向阳25610 分钟前
SpringBoot+vue前后端分离整合sa-token(无cookie登录态 & 详细的登录流程)
java·vue.js·spring boot·后端·sa-token·springboot·登录流程
巷北夜未央15 分钟前
Python每日一题(14)
开发语言·python·算法
XiaoLeisj26 分钟前
【MyBatis】深入解析 MyBatis XML 开发:增删改查操作和方法命名规范、@Param 重命名参数、XML 返回自增主键方法
xml·java·数据库·spring boot·sql·intellij-idea·mybatis
风象南27 分钟前
SpringBoot实现数据库读写分离的3种方案
java·spring boot·后端
振鹏Dong34 分钟前
策略模式——本质是通过Context类来作为中心控制单元,对不同的策略进行调度分配。
java·策略模式
ChinaRainbowSea43 分钟前
3. RabbitMQ 的(Hello World) 和 RabbitMQ 的(Work Queues)工作队列
java·分布式·后端·rabbitmq·ruby·java-rabbitmq
雾月5543 分钟前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
Y.O.U..1 小时前
今日八股——C++
开发语言·c++·面试
melck1 小时前
liunx日志查询常用命令总结
java·服务器·网络