redis自学(16)select

Select

selectLinux中最早的I/O多路复用实现方案:

 

 

nfdsFD遍历的一个上限,遍历到这个值的时候,就意味着不用再往后去遍历了。

fds_bits 是存储1024个比特位,代表1024fd,这个数量是__d_mask四个字节共32个比特位乘以fds_bits32长度得到的

Select的执行流程:

 

 

根据fd的整数值,把对应的比特位赋值为1

 

 

传递进内核空间,遍历,有就绪的就后续操作,没有就绪的就休眠

 

 

有就绪的或者休眠唤醒有就绪数据,就根据队对应的fd修改,就绪的还是1,未就绪的就删除或者标记为0

 

 

然后把结果拷贝回用户空间,然而并不知道到底哪个fd就绪了,就要遍历找到就绪的fd

 

Select模式存在的问题:

  •  需要将整个fd_set从用户空间拷贝到内核空间,select结束还要再次拷贝回用户空间
  •  Select无法得知具体是哪个fd就绪,需要遍历整个fd_set
  •  fd_set监听的fd数量不能超过1024
posted @ 2024-03-12 11:05  蓝海的bug本  阅读(22)  评论(0编辑  收藏  举报