降低 CPU 占用率的方法

2024-03-01 02:48
文章标签 方法 cpu 降低 占用率

本文主要是介绍降低 CPU 占用率的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CPU 占用率和什么有关?

答:1.单位时间内执行的指令数目多少(用户时间);2.I/O操作时间(等待时间);3.线程调度花费的时间(软/硬中断、优先级调整时间)。

举个例子:

好比一个大人,每次来回可以扛一袋大米,每天的任务要求扛 60 袋,假定来回的路程花费的时间为 10 分钟,如果要全速完成(不存在休息),那么需要 10 小时,如果我们选择 10 小时为单位,那么在这个时间段内跑了 60 个不带休息的来回(100% 占用);如果我们每次来回允许其休息 10 分钟(执行时间 Exec(10),休息时间Sleep(10)),那么平均的 CPU 占用就会在 50%,但是如果高精度绘制 CPU 占用曲线图,会发现 CPU 实际上是 10 分钟 100%,10 分钟 0%,如何平均——即把 Sleep(10) 穿插到 Exec(10) 中?

结论1:通过挂起线程去减少每个/单个线程单位时间内连续执行的用户指令数目,是降低 CPU 占用的最好途径,但弊端是:导致任务完成的延期。

例子2:

每天要扛 600 袋米,显然一个大人是扛不完了,所以我们要雇佣 10 个人,每个人到了扛米的地方,先用手机打个电话通知大家,剩余几袋,需不需要再派人来扛(WaitForSingleObject,等待“需要扛米通知”的信号量,实际上就是为了保护,公共变量临界区同时被多个线程访问所导致的错误)?收到通知后(第一个人/线程扛了米,变量恢复到无线程访问,此时可以解锁临界区并且选取第二个线程去访问),在第一个人扛米刚准备回来时,第二个人去扛米,当然到了扛米地点也要打电话通知大家!如此一来,仍然是一天就能完成 600 袋米的作业量。

结论2:

在多核处理器中,多线程技术明显的提高了系统的吞吐量,平均了每个核的 CPU 占用率,但是需要话费较小的管理时间为代价:多个线程竞争 CPU 资源,每次谁可以竞争成功就是如何调度所要花费的时间,而一个任务被逻辑上的分派给不同的线程,但实际上还是位于公共区,就会带来为了防止并发访问资源带来的冲突添加等待信号的时间代价。

注意:对于单核处理器,多线程技术不见得会降低 CPU 占用率,反而会增加占用率,虚拟出来的人手可能导致 CPU 超负荷运转。

例子3:

刚才那 10 个人,每个人都去扛米,但是工头不放心,不断地打电话问询剩余米的数目,导致效率低小,CPU 占用提高。

结论:在循环中,任务的执行是有条件的,那么这个条件语句最好不是异步的,而是阻塞的,这样可以降低 CPU 占用率。

总结:

降低CPU的占用率,基本就是不要用while(1) 空转,用消息、通知等配合多线程在多核处理中的作用;如果有些任务只有跳进成熟才会被执行,比如单独一个线程接收 socket 数据,收到后解析,那么条件收到数据就不要用异步方式不停判断返回值,而是使用同步阻塞的方式

这篇关于降低 CPU 占用率的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/760972

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

Window Server2016加入AD域的方法步骤

《WindowServer2016加入AD域的方法步骤》:本文主要介绍WindowServer2016加入AD域的方法步骤,包括配置DNS、检测ping通、更改计算机域、输入账号密码、重启服务... 目录一、 准备条件二、配置ServerB加入ServerA的AD域(test.ly)三、查看加入AD域后的变

Window Server2016 AD域的创建的方法步骤

《WindowServer2016AD域的创建的方法步骤》本文主要介绍了WindowServer2016AD域的创建的方法步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、准备条件二、在ServerA服务器中常见AD域管理器:三、创建AD域,域地址为“test.ly”

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,