驱动开发,IO多路复用(select,poll,epoll三种实现方式的比较)

1.IO多路复用介绍

  • 在使用单进程或单线程情况下,同时处理多个输入输出请求,需要用到IO多路复用;
  • IO多路复用有select/poll/epoll三种实现方式;
  • 由于不需要创建新的进程和线程,减少了系统资源的开销,减少了上下文切换的次数;
    • 上下文切换:从A进程切换到B进程,A进程的资源要完全替换成B进程的资源,是一个耗时的操作;
  • 如果进程同时监听的多个硬件数据都没有准备好,进程切换进入休眠状态,当一个或者多个硬件数据准备就绪后,休眠的进程被唤醒,读取准备好的硬件数据。

 

2.相似的select/epoll方式介绍

框架图: 

原理:(fd代表文件描述符) 

应用层:将要监听的fd添加到可集合中,判断事件的发生,发生的事件保留到集合中,没发生的被清除;

VFS层(虚拟文件系统):(自动执行)

  1.         将用户空间的fd拷贝到内核空间,用户空间的fd被清空;
  2.         通过fd回调每个fd对应的操作方法;
  3.         判断操作方法的返回值,如果全为0,硬件数据都没准备好,进程进入休眠态;
  4.         收到事件唤醒提示,根据集合中的每一个fd回调poll方法,找出发生事件的fd;
  5.         将发生事件的fd重新拷贝回用户空间事件集合;

驱动层:向上提交等待队列头,判断condition的值,根据事件是否发生给一个合适的返回值;

硬件中断层:更改condition值,唤醒进程;

select和poll:

  •         都需要把监控的文件描述符集合都在用户空间和内核空间来回拷贝,消耗资源大;
  •         当有事件发生,都需要遍历文件描述符集合确认哪一个事件发生;
  •         select方式能监听的文件描述符有限(1024个),poll使用pollfd结构解决了此问题;

 

3.epoll方式介绍

        被称为当前时代最好用的io多路复用方式,epoll最大的好处在是监听的fd数目的增长,不会影响执行效率;

        核心操作:一棵树(红黑树)、一张表(内核链表)以及三个接口(epoll_create/epoll_ctl/epoll_wait);

  • epoll_create:创建一个epoll句柄(红黑树根节点);
  • epoll_ctl:实现对于epoll的控制(添加/修改/删除事件);
  • epoll_wait:阻塞等待准备好的文件描述符;

 

框架图 : 

 原理:

        epoll要把检测的事件fd挂载到内核空间红黑树上,遍历红黑树,调用每个fd对应的操作方法,找到发生事件的fd,如果没有发生事件的fd,进程休眠,如果事件发生,将发生事件的fd拷贝一份放到内核链表,每个节点对应一个fd,最后把链表的节点信息传递到用户空间的数组中,用户空间无需判断事件的发生,只需要判断事件类型(读写类型等)。

 应用层:

  •         创建句柄(红黑树);
  •         打开设备文件;
  •         将fd添加到红黑树上;
  •         监听事件是否发生;
  •         循环遍历数组,做事件的处理(判断事件类型进行读写);

VFS层(虚拟文件系统):(自动执行)

  1.         通过fd回调每个fd对应的操作方法;
  2.         判断操作方法的返回值,如果全为0,硬件数据都没准备好,进程进入休眠态;
  3.         收到事件唤醒提示,根据集合中的每一个fd回调poll方法,找出发生事件的fd;
  4.         将发生事件的fd拷贝到内核链表中;

驱动层:向上提交等待队列头,判断condition的值,根据事件是否发生给一个合适的返回值;

硬件中断层:更改condition值,唤醒进程;

4.select/poll,epoll对比总结

相同点:

        select,poll,epoll都是IO多路复用方式,本质上都是同步IO(读写就绪后自己负责读写);

不同点:   
  •         select/poll每次调用都要把fd集合从用户空间拷贝到内核空间,最后在从内核空间拷贝到用户空间;epoll每次调用,任意个发生事件fd往内核队列挂一次,链表数据从内核空间拷贝到用户空间一次);
  •         select最大监测事件有限(1024个),poll/epoll不受限制;
  •         判断事件发生:select/poll需要不断轮询监测集合fd,epoll直接检查内核链表即可;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/135202.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1. 快速体验 VSCode 和 CMake 创建 C/C++项目

1. 快速体验 VSCode 和 CMake 创建 C/C项目 本章的全部代码和markdown文件地址: CMake_Tutorial,欢迎互相交流. 此次介绍的内容都是针对于 Linux 操作系统上的开发过程. 1.1 安装开发工具 VSCode: 自行下载安装, 然后安装插件 Cmake:在 Ubuntu 系统上, 可以采用 ap…

Ae 效果:CC Hair

模拟/CC Hair Simulation/CC Hair CC Hair(CC 毛发)可以在源图像上模拟生成毛发、绒线等,并可调整它们的长度、方向、重量等属性,从而创建出非常独特的效果。 CC Hair 本质上是基于 Alpha 通道来生成毛发,无毛发处将变…

Debian 12安装Docker

1.更新系统包 #apt update 2.安装依赖包 #apt install apt-transport-https ca-certificates curl gnupg lsb-release 3.添加Docker源 (1)添加Docker 官方GPG密钥 #curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /usr/s…

GraphQL基础知识与Spring for GraphQL使用教程

文章目录 1、数据类型1.1、标量类型1.2. 高级数据类型 基本操作2、Spring for GraphQL实例2.1、项目目录2.2、数据库表2.3、GraphQL的schema.graphql2.4、Java代码 3、运行效果3.1、添加用户3.2、添加日志3.3、查询所有日志3.4、查询指定用户日志3.5、数据订阅 4、总结 GraphQL…

基于LUT查找表方法的图像gamma校正算法FPGA实现,包括tb测试文件和MATLAB辅助验证

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 将gamma2.2和gamma1/2.2的数据分别导入到matlab进行对比: 2.算法运行软件版本 matlab2022a 3.部分核心程序 timescale 1ns / 1ps //…

C2基础设施威胁情报对抗策略

威胁情报是指在信息安全和安全防御领域,收集、分析和解释与潜在威胁相关的信息,以便预先发现并评估可能对组织资产造成损害的潜在威胁,是一种多维度、综合性的方法,其通过信息的收集、分析和研判,帮助组织了解可能对其…

Vue.js vs React:哪一个更适合你的项目?

🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…

小谈设计模式(2)—简单工厂模式

小谈设计模式(2)—简单工厂模式 专栏介绍专栏地址专栏介绍 简单工厂模式简单工厂模式组成抽象产品(Abstract Product)具体产品(Concrete Product)简单工厂(Simple Factory)三者关系 …

【MySQL】MySQL索引的定义、分类、Explain、索引失效和优化

索引的介绍 索引是帮助MySQL高效获取数据的数据结构 MySQL在存储数据之外,数据库系统中还维护着满足特定查找算法的数据结构,这些数据结构以某种引用(指向)表中的数据,这样我们就可以通过数据结构上实现的高级查找算法来快速找到我们想要的数…

JSP 学习笔记(基础)

出现背景: 由于 Servlet 输出 HTML 比较困难,所以出现了 JSP 这个代替品。 特点: 基于文本,HTML 和 Java 代码共同存在(用 write() 来写 HTML 标签)其本身就是个被封装后的 Servlet(被编译为…

springboot对接postgres

安装postgres 注意:下述链接方式会自动创建数据库steven_russell,若需要创建其他数据库,可以手动执行命令创建数据库 docker run --name postgres \ -p 5432:5432 \ -e POSTGRES_USERsteven_russell \ -e POSTGRES_PASSWORD123456 \ -itd --privilegedtrue postgre…

D数树,牛客小白月赛78,思维

链接:登录—专业IT笔试面试备考平台_牛客网 来源:牛客网 时间限制:C/C 1秒,其他语言2秒 空间限制:C/C 262144K,其他语言524288K 64bit IO Format: %lld 题目描述 “开导!” 众所周知&#…

BGP路由属性

任何一条BGP路由都拥有多个路径属性(Path Attributes),当路由器通告BGP路由给它的对等体时,该路由将会携带多个路径属性,这些属性描述了BGP路由的各项特征,同时在某些场景下也会影响BGP路由优选的决策。 一…

【Flink】FlinkCDC获取mysql数据时间类型差8小时时区解决方案

1、背景: 在我们使用FlinkCDC采集mysql数据的时候,日期类型是我们很常见的类型,但是FlinkCDC读取出来会和数据库的日期时间不一致,情况如下 FlinkCDC获取的数据中create_time字段1694597238000转换为时间戳2023-09-13 17:27:18 而数据库中原始数据如下,并没有到下午5点…

01.qtcreator介绍

四、创建第一个qtcreator项目并确定文件和目录的作用 bin: 存放编译好输出的dll文件和执行文件 doc: 存放文档 lib: 存放库文件 src: 存放源码 注意: QtCreator创建路径不要使用中文路径;创建.h和.cpp文件时,使用小写;windows大…

解读|美创深度参与5项电信和互联网行业数据安全标准发布实施

《数据安全法》、《个人信息保护法》等法律法规的颁布实施,坚持安全和发展并重的原则,积极应对复杂严峻的安全风险与挑战,加速构建数据安全保障体系,成为电信和互联网行业重要工作。 “安全发展、标准先行”,标准化工作…

一文详解TCP三次握手四次挥手

文章目录 TCP的三次握手和四次挥手三次握手四次挥手 TCP的三次握手和四次挥手 基本概念 SYN(Synchronize Sequence Numbers,同步序列数字):用于建立连接的同步信号。 SYN 序列号的作用是用于标识每个数据包中的字节流的起始位置。…

线上论坛之单元测试

对线上论坛进行单元测试的测试报告 源码地址:https://gitee.com/coisini-thirty-three/forum 一、用户部分(UserServiceImplTest) 1.创建普通用户 测试名称 createNormalUser() 测试源码 Test void createNormalUser() { // 构造用户 User …

指针和数组笔试题解析

大家好,我们今天来学习有关于指针和数组的笔试题解析。 在之前的C语言学习中我们知道了数组名代表的是数组首元素的地址,而有两个例外,就是sizeof中和&符操作取的就是整个数组的地址,那么我们今天的学习重点就是这些关于数组…

哈希(hash)——【C++实现】

本章gitee代码仓库:Hash 文章目录 💐1. 哈希概念🌻2. 哈希冲突🌼3. 哈希函数🌸3.1 哈希函数设计原则🌸3.2 常见哈希函数 🪴4. 哈希冲突解决方案🌱4.1 闭散列——开放定址法&#x1f…