BIO、NIO和AIO

一、同步和异步,阻塞和非阻塞

       同步:在没有得到结果之前,该调用不返回。

      异步:客户端在调用服务之后直接返回,在服务端处理完成后通过通知或者回调客户端函数来返回结果。

      阻塞:客户端等待结果返回时,线程会被阻塞。

     非阻塞:客户端等待结果返回时,线程不会被阻塞,可以处理其他事情。

二、BIO(同步阻塞Block IO)

服务器实现模式:一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销。

伪异步IO

通过线程池机制优化了BIO模型

三、NIO(同步非阻塞 Non-block IO)

服务器实现模式为一个请求一个线程,但客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有I/O请求时才启动一个线程进行处理。

四、AIO(异步非阻塞 )

服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理。

      

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值