Linux多路复用机制原理分析--select/poll

前言

Linux访问设备的IO模型主要有五种,分别是非阻塞IO模型、阻塞IO模型、IO多路复用模型、信号驱动模型以及异步IO模型。本文主要分析IO多路复用模型,Linux下的IO多路复用模型主要有select/poll/epoll等机制实现。
IO多路复用模型可以实现以非阻塞的方式监听多个设备,具体的模型如下图所示
在这里插入图片描述图中可以看出,select/poll可以监听多个设备,只要任意一个设备满足条件,select/poll都会返回具体的响应,否则睡眠等待。简而言之就是,将用户感兴趣的条件让select/poll进行监听。

原理

select调用分析

在这里插入图片描述从上图中可以看出以下几点:
1、select的系统调用最终核心操作在do_select函数中进行处理,原函数参考fs/select.c文件。
2、do_select函数主要完成以下关键操作

  • 调用poll_initwait初始化poll_wqueues结构体,包含回调函数的初始化,用于关联驱动函数进行回调处理;
  • 循环遍历所监测的文件描述符,当满足监测条件时,调用*f_op->poll(即结构体file_operations中的成员函数unsigned
    int (*poll) (struct file *, struct poll_table_struct *);)函数进行处理;
  • 在监测条件不满足的情况下,调用schedule_timeout进行休眠处理,当超时或者被其他信号中断唤醒。

3、do_select函数退出循环的条件:监测条件满足,超时以及被其他信号中断唤醒。

select/poll的差异

poll与select基本类似,都是采用轮询文件描述符的方式来进行监测,在文件描述符较大的情况下,开销会增大导致性能下降,select默认最大支持文件描述符数量1024,poll没有具体限制。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值