bio与nio的区别

bio nio 的区别
1 bio 同步阻塞 io :在此种⽅式下,⽤户进程在发起⼀个 IO 操作以后,必须等待 IO 操作的完成,只有当真正完成了 IO 操作以后,⽤户
进程才能运⾏。 JAVA 传统的 IO 模型属于此种⽅式!
2 nio 同步⾮阻塞式 I/O java NIO 采⽤了双向通道进⾏数据传输,在通道上我们可以注册我们感兴趣的事件:连接事件、读写事件;
NIO 主要有三⼤核⼼部分: Channel (通道), Buffer (缓冲区), Selector 。传统 IO 基于字节流和字符流进⾏操作,⽽ NIO 基于 Channel
Buffer (缓冲区)进⾏操作,数据总是从通道读取到缓冲区中,或者从缓冲区写⼊到通道中。 Selector (选择区)⽤于监听多个通道的事件
(⽐如:连接打开,数据到达)。因此,单个线程可以监听多个数据通道。
1. BIO Blocking I/O ):同步阻塞 I/O 模式,数据的读取写⼊必须阻塞在⼀个线程内等待其完成。这⾥使⽤那个经典的烧开⽔例⼦,
这⾥假设⼀个烧开⽔的场景,有⼀排⽔壶在烧开⽔, BIO 的⼯作模式就是, 叫⼀个线程停留在⼀个⽔壶那,直到这个⽔壶烧开,才去
处理下⼀个⽔壶。但是实际上线程在等待⽔壶烧开的时间段什么都没有做。
2. NIO New I/O ):同时⽀持阻塞与⾮阻塞模式,但这⾥我们以其同步⾮阻塞 I/O 模式来说明,那么什么叫做同步⾮阻塞?如果还拿
烧开⽔来说, NIO 的做法是叫⼀个线程不断的轮询每个⽔壶的状态,看看是否有⽔壶的状态发⽣了改变,从⽽进⾏下⼀步的操作。
3. AIO Asynchronous I/O ):异步⾮阻塞 I/O 模型。异步⾮阻塞与同步⾮阻塞的区别在哪⾥?异步⾮阻塞⽆需⼀个线程去轮询所有
IO 操作的状态改变,在相应的状态改变后,系统会通知对应的线程来处理。对应到烧开⽔中就是,为每个⽔壶上⾯装了⼀个开关,⽔
烧开之后,⽔壶会⾃动通知我⽔烧开了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值