Linux 学习笔记之 --- select 与 poll 事件模型详解

 
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 集合拷贝到用户态
 
伪代码:
1 fd = iosocket_coonnect()  #建立网络连接
2 fd_set.add(fd)  #向fd_set集合中添加fd
3 copy_from_user(fd_set)   #从用户态拷贝 fd_set 到内核态
4 for fd in fd_set:   #遍历 fd_set 对就绪的 fd 执行相关操作
5     doing(fd)

 

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

posted on 2017-04-01 15:03  RobotZhu  阅读(561)  评论(0编辑  收藏  举报

导航