【嵌入式Linux】阻塞与非阻塞IO为何能降低CPU使用率

本文主要记录嵌入式Linux内核中阻塞与非阻塞IO访问的应用,以及解释了为何二者可以降低CPU使用率

阻塞与非阻塞IO为何能降低CPU使用率

  • 0. 授权须知
  • 1. 通俗解释
  • 2. 场景描述
  • 3. 阻塞IO之———等待队列使用详解
  • 4. 非阻塞IO之———poll select
    • 4.1 poll 访问
    • 4.2 selct 访问
  • 5. 为什么阻塞式IO也能降低CPU的使用率?

0. 授权须知

📋 个人简介

  • 💖 作者简介:大家好,我是喜欢记录零碎知识点的小菜鸟。😎
  • 📝 个人主页:欢迎访问我的 Ethernet_Comm 博客主页🔥
  • 🎉 支持我:点赞👍+收藏⭐️+留言📝
  • 📣 系列专栏:嵌入式Linux开发 🍁
  • 💬格言:写文档啊不是写文章,重要的还是直白!🔥

转载文章,禁止声明原创;不允许直接二次转载,转载请根据原文链接联系作者

若无需改版,在文首清楚标注作者及来源/原文链接,并删除【原创声明】,即可直接转载。
但对于未注明转载来源/原文链接的文章,我将保留追述的权利。

作者:积跬步、至千里

1. 通俗解释

当应用程序对设备驱动操作的时候,比如应用程序的 read 操作,如果不能获取到设备资源,则

1️⃣ :阻塞式IO:会将应用程序对应的线程 挂起,直到设备资源可以获取

2️⃣ :非阻塞IO:应用程序会一直 轮询,直到设备可以获取

  • 阻塞式 IO :当设备文件不可操作的时候,线程可以进入 休眠态让出CPU的资源
  • 非阻塞式IO:线程会一直处于运行态,任务无法立即完成,函数直接返回或者一直轮询,占用CPU资源,造成 资源浪费

image-20240429142257905

2. 场景描述

应用程序通过 read 函数读取开发板是否有按键按下,若有按键按下,则打印信息

  • 阻塞式 IO :当没有按键按下时,应用程序的线程可以进入休眠态,让出CPU资源;当按下按键时,在按键中断中唤醒线程;
  • 非阻塞式IO:一直 read , read , read , read, read , read, read , read, read , read……………………………………

使用 top 指令查看,可以看到非阻塞式IO尽管只有一个read操作,但是却占据了CPU的大部分资源

image-20240429151112934

3. 阻塞IO之———等待队列使用详解

一般在 中断函数 中实现进程的 唤醒

  • 初始化等待队列头 wait_queue_head_t
  • 将等待队列项加入到等待队列中 wait_queue_head_t
  • 当设备不可访问时,将进程对应的等待队列项添加到创建的等待队列头中,加入以后进程才能进入休眠状态
  • 当设备可以访问时,从等待队列头中移除 进程对应的等待队列项
wait_queue_head_t head_wait;	/* 等待队列头 *//* 1. 初始化等待队列头 */
init_waitqueue_head(&head_wait);/* 2. 定义并初始化一个等待队列,给当前正在运行的进程创建并初始化一个等待队列项 */
DECLARE_WAITQUEUE(wait, current);	// current 表示等待队列属于哪个进程/*3.设备不可访问时,将等待队列添加到等待队列头*/
add_wait_queue(&head_wait,&wait);
__set_current_state(TASK_INTERRUPTIBLE); // 设置当前进程的状态,可被信号打断
schedule();								// 进行一次任务切换,当前进程进入休眠态,休眠后程序会停留在这里/*4.当设备可以访问时,将当前进程从等待队列中移除*/
if(signal_pending(current))	 return;           // 若是被信号唤醒的,则返回,继续休眠
__set_current_state(TASK_RUNNING);            /* 若果是在按键中断中唤醒的,则将当前任务设置为运行状态 */
remove_wait_queue(&head_wait,&wait);/*5.进程是在哪里被唤醒的????*/
/*当发生按键中断时,在中断回调函数中开启了 timer 定时器,在timer 定时器的中断回调函数中 */
wake_up_interruptible(&head_wait);    // 在这里唤醒了等待队列

使用等待队列后,使用 top指令查看,CPU的使用率立马降下来了

image-20240429151257884

4. 非阻塞IO之———poll select

应用程序采用 poll selct epoll 函数,都会调用驱动程序的 file_operations 操作集中的 poll 函数 的回调函数

unsigned int (*poll) (struct file *, struct poll_table_struct *);

4.1 poll 访问

【应用程序】

poll 函数:

参数1:文件描述符集合

参数2:文件描述符数量

参数3:超时时间

struct pollfd fds;
int ret = 0;
/* 构造结构体 */
fds.fd = fd;
fds.events = POLLIN;
while(1){ret = poll(&fds, 1, 500);if(ret){   									/* 数据有效 */ret = read(fd, &data, sizeof(data));	/* 读取数据 */}else if (ret == 0) { 	/* 超时 */}else if (ret < 0) {	/* 错误 */	}
}

【驱动程序】

unsigned int imx6uirq_poll(struct file *filp, struct poll_table_struct *wait)
{/* 将等待队列头添加到poll_table中 */poll_wait(filp, &head_wait, wait);  // 不会阻塞
}/*在中断中唤醒进程*/
wake_up_interruptible(&head_wait);

4.2 selct 访问

【应用程序】

while (1) {	FD_ZERO(&readfds);FD_SET(fd, &readfds);/* 构造超时时间 */timeout.tv_sec = 0;timeout.tv_usec = 500000; /* 500ms */ret = select(fd + 1, &readfds, NULL, NULL, &timeout);switch (ret) {case 0: 	/* 超时 *//* 用户自定义超时处理 */break;case -1:	/* 错误 *//* 用户自定义错误处理 */break;default:  /* 可以读取数据 */if(FD_ISSET(fd, &readfds)) {ret = read(fd, &data, sizeof(data));if (ret < 0) {/* 读取错误 */} else {if (data)printf("key value=%d\r\n", data);}}break;}	}

5. 为什么阻塞式IO也能降低CPU的使用率?

⚠️ : 非阻塞并不是不断的轮询,而是 直接返回

⚠️ : 在自定义规定的时间范围内,若没有可用的输入输出操作,则直接返回,而不是等待

阻塞和非阻塞都降低了CPU的使用率,是因为当驱动资源不可用时

  • 阻塞,线程休眠了,不会一直占用CPU的使用权;

  • 非阻塞,操作系统会立即返回一个错误码表示数据读取失败,并降其发给应用程序,然后系统可以执行其他进程,应用程序的当前进程会立即返回结果不会等待太久

  • 普通访问:应用程序会一直等待,会大部分时间都彻底阻塞在这个进程中

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

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

相关文章

华为L410终端及麒麟KOS上如何安装安卓应用

原文链接&#xff1a;华为L410终端及麒麟KOS上如何安装安卓应用 Hello&#xff0c;大家好啊&#xff01;随着移动应用的普及&#xff0c;越来越多的用户希望在个人电脑上运行安卓应用&#xff0c;以便更好地整合工作和生活中的信息。特别是在华为L410终端和麒麟KOS操作系统上&a…

在线教程|零门槛部署 Llama 3,70B 版本只占 1.07G 存储空间,新用户免费体验 8B 版本

4 月 18 日&#xff0c;Meta 宣布开源 Llama 3&#xff0c;这个号称「迄今为止最好的开源大模型」一经发布&#xff0c;立刻引爆科技圈&#xff01; 发布当天恰逢斯坦福大学教授、AI 顶尖专家吴恩达的生日&#xff0c;作为 AI 开源倡导者&#xff0c;他激动地发文表示&#xff…

亿图图示使用教程

亿图图示是一款强大的图形绘制工具&#xff0c;可以用于创建流程图、思维导图、组织结构图等多种类型的图表。下面是一些基本的使用教程&#xff1a; 下载和安装&#xff1a;首先&#xff0c;你需要在官方网站上下载亿图图示的安装包&#xff0c;然后按照提示进行安装。 新建项…

Tesla P4终于在DL580 Gen9上面跑起来了!

正文共&#xff1a;666 字 11 图&#xff0c;预估阅读时间&#xff1a;1 分钟 跌跌撞撞&#xff0c;从Tesla M4终于走到了Tesla P40&#xff0c;显存从4 GB到8 GB&#xff0c;最后再到24 GB&#xff0c;真是不容易。 回顾一下&#xff0c;Tesla M4是最早开始搞的&#xff0c;经…

CI/CD:基于kubernetes的Gitlab搭建

1. 项目目标 &#xff08;1&#xff09;熟悉使用k8s环境搭建Gitlab &#xff08;2&#xff09;熟练应用Gitlab基本配置 2. 项目准备 2.1. 规划节点 主机名 主机IP 节点规划 k8s-master 10.0.1.1 kube_master k8s-node1 10.0.1.2 kube_node k8s-node2 10.0.1.3 k…

【AI心理咨询测评】一年后,AI心理咨询的路还有多远?——5例AI模型心理咨询能力测评对比

前言 随着GPT横空出世&#xff0c;AI心理健康的市场开始逐渐被开拓。有人联想到线上以GPT作为基础&#xff0c;开发可线上心理咨询的AI&#xff0c;例如国内的聆心智能。然而&#xff0c;这一想法也遭到了无数人的质疑&#xff1a;“连聊天都尚不能很好完成&#xff0c;去做心…

第⑰讲:Ceph集群各组件的配置参数调整

文章目录 1.Ceph集群各组件的配置文件1.1.Ceph各组件配置方式1.2.ceph临时查看、修改配置参数的方法 2.调整Monitor组件的配置参数删除Pool资源池2.1.临时调整配置参数2.2.永久修改配置参数 1.Ceph集群各组件的配置文件 1.1.Ceph各组件配置方式 Ceph集群中各个组件的默认配置…

【Jenkins】持续集成与交付 (一):深入理解什么是持续集成?

🟣【Jenkins】持续集成与交付 (一):深入理解什么是持续集成? 1、软件开发生命周期与持续集成2、 持续集成的流程3、持续集成的好处4、Jenkins的应用实践5、结语💖The Begin💖点点关注,收藏不迷路💖 1、软件开发生命周期与持续集成 软件开发生命周期(SDLC)是指软…

C语言:项目实践(贪吃蛇)

前言&#xff1a; 相信大家都玩过贪吃蛇这款游戏吧&#xff0c;贪吃蛇是久负盛名的游戏&#xff0c;它也和俄罗斯方块&#xff0c;扫雷等游戏位列经典游戏的行列&#xff0c;那贪吃蛇到底是怎么实现的呢&#xff1f; 今天&#xff0c;我就用C语言带着大家一起来实现一下这款游戏…

微软如何打造数字零售力航母系列科普04 - 微软联合Adobe在微软365应用程序中工作时推出新的生成式AI功能

微软和Adobe正在合作&#xff0c;将情境营销见解和工作流程引入微软Copilot&#xff0c;以提供生成的人工智能功能&#xff0c;使营销人员和营销团队能够在自然的工作流程中实现更多目标。 这些新的集成功能将在生产力和协作工具&#xff08;如Outlook、Teams和Word&#xff0…

【事业单位专场】联考、省市统考、单独招考

一、考编概述 1、事业单位类别 事业单位是指由国家出资或委托管理的公共机构&#xff0c;其主要职能是为社会提供公共服务。在中国&#xff0c;事业单位覆盖了科研、教育、文化和卫生等多个领域&#xff0c;并且有着不同的类型。以下是一些主要的分类&#xff1a; 教育事业单…

NLP(10)--TFIDF优劣势及其应用Demo

前言 仅记录学习过程&#xff0c;有问题欢迎讨论 TF*IDF&#xff1a; 优势&#xff1a; 可解释性好 可以清晰地看到关键词 即使预测结果出错&#xff0c;也很容易找到原因 计算速度快 分词本身占耗时最多&#xff0c;其余为简单统计计算 对标注数据依赖小 可以使用无标注语…

【状态机dp 状态压缩 分组】1994. 好子集的数目

本文涉及知识点 动态规划汇总 动态规划 状态机dp 状态压缩 分组 LeetCode1994. 好子集的数目 给你一个整数数组 nums 。如果 nums 的一个子集中&#xff0c;所有元素的乘积可以表示为一个或多个 互不相同的质数 的乘积&#xff0c;那么我们称它为 好子集 。 比方说&#xff…

离散数学之命题逻辑思维导图+大纲笔记(预习、期末复习,考研,)

大纲笔记&#xff1a; 命题逻辑的基本概念 命题与联结词 命题 命题是推理的基本单位 真命题&#xff0c;假命题 特征 陈述句 唯一的真值 是非真即假的陈述句 非命题 疑问句 祈使句 可真可假 悖论 模糊性 三个基本概念 复合命题 真值取决于原子命题的值和逻辑联结词 原子命题 逻…

基于SSM的考研助手系统(有报告)。Javaee项目。ssm项目。

演示视频&#xff1a; 基于SSM的考研助手系统&#xff08;有报告&#xff09;。Javaee项目。ssm项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xff0c;通过Spring Spri…

【Java】图书管理系统 介绍与实现

欢迎浏览高耳机的博客 希望我们彼此都有更好的收获 感谢三连支持&#xff01; 1.介绍 图书馆作为知识的殿堂和学术的中心&#xff0c;其管理系统不仅是图书馆管理的必备工具&#xff0c;更是为用户提供优质、高效服务的重要保障&#xff0c;促进了知识的传播和学术的发展。随着…

基于FPGA的数字信号处理(6)--如何确定Verilog表达式的符号

前言 尽管signed语法的使用能带来很多便利&#xff0c;但同时也给表达式的符号确定带来了更多的不确定性。比如一个有符号数和一个无符号数的加法/乘法结果是有符号数还是无符号数&#xff1f;一个有符号数和一个无符号数的比较结果是有符号数还是无符号数&#xff1f;等等。接…

力扣刷题Day2

题目链接&#xff1a; 24. 两两交换链表中的节点 - 力扣&#xff08;LeetCode&#xff09; 效果&#xff1a; 解题思路&#xff1a; 给定一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后的链表。 注意不可以只是单纯的改变节点内部的值&#xff0c;而…

《QT实用小工具·四十七》可交互的创意动态按钮

1、概述 源码放在文章末尾 该项目实现了可交互的创意动态按钮&#xff0c;包含如下功能&#xff1a; 所有颜色自定义 鼠标悬浮渐变 两种点击效果&#xff1a;鼠标点击渐变 / 水波纹动画&#xff08;可多层波纹叠加&#xff09; 额外鼠标移入/移出/按下/弹起的实时/延迟共8种事…

51单片机两个中断及中断嵌套

文章目录 前言一、中断嵌套是什么&#xff1f;二、两个同级别中断2.1 中断运行关系2.2 测试程序 三、两个不同级别中断实现中断嵌套3.1 中断运行关系3.2 测试程序 总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 课程需要&#xff1a; 提示&#x…