`
jokermanager
  • 浏览: 140417 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

阻塞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是不阻塞的。

分享到:
评论
3 楼 randyjiawenjie1 2013-12-16  
终于遇到一个人讲清楚了
2 楼 jokermanager 2008-06-28  
1、异步与同步的区别:异步不会引起request进程阻塞。而同步会。

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

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

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

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

6、由于非阻塞request不会一直与response保持连接,这样会降低response端压力,也就提高了并发性。
1 楼 FGhost 2008-06-26  
两个问题:
      1. "read操作是否阻塞,阻塞I/O是阻塞的,而异步I/O是不阻塞的" --阻塞是在等待,那不阻塞呢? 如果不是在等是在做什么?不是一样要等到kernel copy数据到socket buffer。
      2。非阻塞 是怎么提高并发的?

相关推荐

Global site tag (gtag.js) - Google Analytics