select 与 poll 工作原理:

1、select 主要是采用轮询的方式来实现对就绪的 fd 处理:
2、poll 和 select 基本相同,主要不同在于 poll 没有对 fd 数量限制
 

工作模型:

Linux -- select 与 poll 事件模型详解

工作流程:

1、用户态创建了网络 IO 连接,假设一个 socket 连接就是一个 fd 文件描述符,那么将 fd 添加到 fd_set 集合中
2、将 fd_set 集合从用户态 copy 到内核态
3、遍历这个 fd_set 集合,找出所有已经就绪的 fd,执行对应 fd 的相关操作
4、将内核态的 fd_set 集合拷贝到用户态

伪代码:

 fd = iosocket_coonnect()  #建立网络连接
 fd_set.add(fd)  #向fd_set集合中添加fd
 copy_from_user(fd_set)   #从用户态拷贝 fd_set 到内核态
 for fd in fd_set:   #遍历 fd_set 对就绪的 fd 执行相关操作
     doing(fd)

 

缺点:

1、每次调用 select ,都需要把 fd 集合从用户态拷贝到内核态,当 fd 比较大的时候,开销大
2、每次都需要对 fd_set 集合进行遍历,开销比较大
3、select 可支持的 fd 描述符比较少,一般是1024 或2048, 可以修改,从新编译内核实现增大,到时效果不好