select 与 poll 工作原理:
1、select 主要是采用轮询的方式来实现对就绪的 fd 处理:
2、poll 和 select 基本相同,主要不同在于 poll 没有对 fd 数量限制
工作模型:
工作流程:
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, 可以修改,从新编译内核实现增大,到时效果不好