第6章 I/O复用 select和poll函数
由于pdf中文字不可复制,就截图居多
其他参考:
https://segmentfault.com/a/1190000003063859#articleHeader16
http://www.cnblogs.com/Anker/archive/2013/08/17/3263780.html
I/O模式
data:image/s3,"s3://crabby-images/b3654/b3654513d548b34a7fc63d8c47e6596e0bf566c7" alt=""
data:image/s3,"s3://crabby-images/ce323/ce323f2832ee85554166edde523763b5ac422d93" alt=""
data:image/s3,"s3://crabby-images/ff22b/ff22bd991ee3ba3c89dcb0ba19edae5dcfe7f2bd" alt=""
多线程中使用阻塞式I/O
data:image/s3,"s3://crabby-images/fbd30/fbd303d4213bee7d8baca09b4ee4f0a5dceb88f8" alt=""
data:image/s3,"s3://crabby-images/90931/90931720896d4e80cde794307fc76d8019288299" alt=""
select
data:image/s3,"s3://crabby-images/f1679/f16790022c1dce3b23a9889f220175cb94df17be" alt=""
data:image/s3,"s3://crabby-images/7b89f/7b89fccd1edc670bcbf66ba8f6dfdf27a549abbe" alt=""
data:image/s3,"s3://crabby-images/3e78e/3e78e630129036a926df8cdf7254417054f2e414" alt=""
看下面这个例子
data:image/s3,"s3://crabby-images/e5fed/e5fed8b279099d80ba783deae3c598713ebad255" alt=""
data:image/s3,"s3://crabby-images/6774e/6774e8d20805e465299b88f75cff585aeafc5986" alt=""
函数返回值表示跨所有描述符集的已就绪的总位数
data:image/s3,"s3://crabby-images/ce270/ce270857e38291884234756ed7f75dff1b80d9d2" alt=""
简单例子
data:image/s3,"s3://crabby-images/16288/162880ea029bcef41fe807e188d039c146d7c205" alt=""
- 被监控的fds需要从用户空间拷贝到内核空间
- 被监控的fds集合中,只要有一个有数据可读,整个socket集合就会被遍历一次调用sk的poll函数收集可读事件
-
select支持的文件描述符数量太小了,默认是1024
poll
data:image/s3,"s3://crabby-images/b5d31/b5d3109244353ee36d411f14b881ded93f117b34" alt=""
epoll
- epoll事先通过epoll_ctl()来注册一 个文件描述符,一旦基于某个文件描述符就绪时,内核会采用类似callback的回调机制,迅速激活这个文件描述符,当进程调用epoll_wait() 时便得到通知
- IO的效率不会随着监视fd的数量的增长而下降。epoll不同于select和poll轮询的方式,而是通过每个fd定义的回调函数来实现的。只有就绪的fd才会执行回调函数。
网友评论