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
操作的状态改变,在相应的状态改变后,系统会通知对应的线程来处理。对应到烧开⽔中就是,为每个⽔壶上⾯装了⼀个开关,⽔
烧开之后,⽔壶会⾃动通知我⽔烧开了。