2008-05-22
阻塞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是不阻塞的。
评论
jokermanager
2008-06-28
1、异步与同步的区别:异步不会引起request进程阻塞。而同步会。
2、阻塞IO一定是同步的。
3、非阻塞IO分为两种:同步和异步的。
4、异步的非阻塞IO在read时,不管有无数据都直接返回。有数据了,会收到kernel copy的事件,来完成读取。
5、同步的非阻塞IO在read时,也是等数据copy完才返回。
6、由于非阻塞request不会一直与response保持连接,这样会降低response端压力,也就提高了并发性。
2、阻塞IO一定是同步的。
3、非阻塞IO分为两种:同步和异步的。
4、异步的非阻塞IO在read时,不管有无数据都直接返回。有数据了,会收到kernel copy的事件,来完成读取。
5、同步的非阻塞IO在read时,也是等数据copy完才返回。
6、由于非阻塞request不会一直与response保持连接,这样会降低response端压力,也就提高了并发性。
FGhost
2008-06-26
两个问题:
1. "read操作是否阻塞,阻塞I/O是阻塞的,而异步I/O是不阻塞的" --阻塞是在等待,那不阻塞呢? 如果不是在等是在做什么?不是一样要等到kernel copy数据到socket buffer。
2。非阻塞 是怎么提高并发的?
1. "read操作是否阻塞,阻塞I/O是阻塞的,而异步I/O是不阻塞的" --阻塞是在等待,那不阻塞呢? 如果不是在等是在做什么?不是一样要等到kernel copy数据到socket buffer。
2。非阻塞 是怎么提高并发的?
发表评论
- 浏览: 8588 次
- 性别:

- 来自: 广州

- 详细资料
搜索本博客
最近加入圈子
最新评论
-
java中堆和堆栈的区别
引用[u][/u][i][/i][b][/b][img][/img][url ...
-- by yinguohui -
阻塞I/O,非阻塞I/O
1、异步与同步的区别:异步不会引起request进程阻塞。而同步会。2、阻塞IO ...
-- by jokermanager -
阻塞I/O,非阻塞I/O
两个问题: 1. "read操作是否阻塞,阻塞I/O是阻塞的,而异步I ...
-- by FGhost






评论排行榜