BIO、NIO、AIO概念

阻塞与非阻塞:

阻塞与非阻塞是进程在访问数据的时候对数据是否准备就绪的一种处理方式。若数据准备就绪,两种方式接着往下执行。若数据没准备就绪,阻塞方式的处理是将一直等待数据准备好后才开始后续的处理。而非阻塞则是直接返回做其他事情。不死等。

同步与异步:

同步和异步都是应用程序和操作系统处理IO所采用的方式。同步是应用程序直接参与IO读写。异步是指所有IO读写都交给操作系统处理,应用程序去做其他事情,操作系统处理完IO后给应用程序一个事件完成通知。同步的方式处理时,应用程序会阻塞在IO读写那。

同步可以是阻塞到IO事件、或是IO事件的轮询(linux的多路复用技术 select 模式),即读写事件交给一个单独的线程处理。提供IO事件的注册功能,并不断去轮询我们的读写缓冲区,看是否有数据准备好,若准备好了就通知相应的注册的读写线程。这样的话,这些读写进程在数据到来之前就可以做其他事情。这个时候阻塞的不是所有的IO线程而只是这个select轮询线程。

JAVA IO模式

BIO:JDK 1.4之前的传统IO,同步阻塞型(同步阻塞所有读写线程,阻塞线程开销大)

NIO:JDK1.4以后,同步非阻塞模型,只阻塞select轮询线程。(轮询缓冲区,并通知相应的监测事件) NIO框架(Netty,Mina)

AIO:JDK1.7以后



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值