非阻塞I/O和阻塞I/O

 

拿 socket举例。

当read数据时,如果这时没有数据可读,阻塞I/O会一直等待有数据读,数据从kernel copy 到socket的buffer后返回;非阻塞I/O会立即返回,但如果有数据可读,非阻塞I/O也是等数据从kernel copy 到socket的buffer后返回。



以上是阻塞与非阻塞I/O的区别,但以上两个例子的read操作都是同步的,是不是很奇怪?点解称其为同步?看看同步的定义就会很明确:

  • A synchronous I/O operation causes the requesting process to be blocked until that I/O operation completes.

  • An asynchronous I/O operation does not cause the requesting process to be blocked.



现在举一个异步的例子就会很明白了,也是对read这个操作,当有数据可读时,异步I/O立即返回,kernel copy数据到socket buffer后,会以事件等通知程序read操作完成。


关键就在于将数据从kernel copy到socket buffer这段时期,read操作是否阻塞,阻塞I/O是阻塞的,而异步I/O是不阻塞的。

1、异步与同步的区别:异步不会引起request进程阻塞。而同步会。

2、阻塞IO一定是同步的。

3、非阻塞IO分为两种:同步和异步的。

4、异步的非阻塞IO在read时,不管有无数据都直接返回。有数据了,会收到kernel copy的事件,来完成读取。

5、同步的非阻塞IO在read时,也是等数据copy完才返回。

6、由于非阻塞request不会一直与response保持连接,这样会降低response端压力,也就提高了并发性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值