在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

計(jì)算CPU使用率的核心所在的內(nèi)容

lhl545545 ? 來(lái)源:RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 作者:RTThread物聯(lián)網(wǎng)操作 ? 2020-06-09 15:28 ? 次閱讀

打開(kāi)電腦的任務(wù)管理器,看著跳動(dòng)的CPU使用率,發(fā)現(xiàn)很舒服。每一個(gè)線(xiàn)程占用了多少CPU清清楚楚,也就能針對(duì)性的確認(rèn)為啥你的電腦跑的慢了。

今天這篇筆記不講每個(gè)任務(wù)(或線(xiàn)程)CPU的使用情況,而是單片機(jī)整體的CPU使用情況,先易后難嘛。

為什么要知道這個(gè)呢?知道這個(gè)有啥用呢?魚(yú)鷹看的書(shū)少,就不寫(xiě)官方話(huà)了,只說(shuō)說(shuō)自己的理解。

CPU使用率越高,意味著系統(tǒng)越繁忙,對(duì)于一些事情的響應(yīng)也就越慢。比如你的電腦CPU使用率占到90%以上,你會(huì)發(fā)現(xiàn)打字變慢了,鼠標(biāo)移動(dòng)變慢了,這都是因?yàn)镃PU占用過(guò)高,導(dǎo)致系統(tǒng)來(lái)不及處理你的鍵盤(pán)和鼠標(biāo)數(shù)據(jù),所以才會(huì)有慢悠悠的表現(xiàn)。

電腦是非實(shí)時(shí)系統(tǒng),要求不高,即使電腦變慢,電腦死機(jī),后果都不是很?chē)?yán)重,但是如果說(shuō)你的嵌入式系統(tǒng)是國(guó)防、醫(yī)療領(lǐng)域的,如果也出現(xiàn)了這些情況,那后果不堪設(shè)想。比如呼吸機(jī)突然出問(wèn)題了,那么對(duì)于病人來(lái)說(shuō),就是災(zāi)難,所以醫(yī)療行業(yè)的產(chǎn)品都會(huì)經(jīng)過(guò)嚴(yán)格的測(cè)試,否則不允許上市。

嵌入式系統(tǒng)使用的大部分應(yīng)該都是實(shí)時(shí)操作系統(tǒng),即所謂的RTOS,它必須對(duì)外界的各種情況作出非常快的響應(yīng),如果不能,那你設(shè)計(jì)的系統(tǒng)就是有問(wèn)題的。

那么如何快速響應(yīng)外界信息呢?就看CPU使用情況了,CPU平時(shí)的使用率越低,越能快速響應(yīng)。怎么理解這句話(huà)?

比如一天時(shí)間里,你要上8個(gè)小時(shí)的班,其他時(shí)間才屬于你自己,如果按一天來(lái)計(jì)算的話(huà),你的CPU利用率是8/24=33.3%,其他時(shí)間可以快速響應(yīng)其他事情,比如別人叫你出去吃飯,如果是在下班時(shí)間,你隨叫隨到,如果是上班時(shí)間,那么叫了你也沒(méi)用,只能等下班之后才行。所以雖然你的CPU利用率才33.3%,但是上班的時(shí)候還是不能及時(shí)響應(yīng)其他事情,因?yàn)樯习嗍莾?yōu)先級(jí)最高的任務(wù)(假設(shè)上班是最高優(yōu)先級(jí)任務(wù))。

這個(gè)例子可能不是很好,換成學(xué)生的例子可能更好一些。比如一個(gè)學(xué)生,每天上7節(jié)課,課間都有休息時(shí)間,假設(shè)還是要上8小時(shí),但是因?yàn)橹虚g不是連續(xù)的,所以雖然你的CPU利用率還是33.3%,但是你在課間時(shí)總能對(duì)一些其他事情做出快速響應(yīng),所以整體性能可能比前一個(gè)例子好一些。

所以設(shè)計(jì)系統(tǒng)時(shí),千萬(wàn)別讓一個(gè)高優(yōu)先級(jí)任務(wù)持續(xù)占用CPU太長(zhǎng)時(shí)間,如果可能的話(huà),盡可能拆分長(zhǎng)任務(wù),否則低優(yōu)先級(jí)的任務(wù)很可能無(wú)法及時(shí)運(yùn)行,外在表現(xiàn)是,系統(tǒng)卡了。

看完這個(gè),很多人就會(huì)想了,我的系統(tǒng)該怎么計(jì)算CPU使用率呢?對(duì)了,我的系統(tǒng)是裸機(jī)的……

不好意思,裸機(jī)系統(tǒng)CPU使用率100%,算不了……

那好,帶操作系統(tǒng)的怎么算,比如uCOSFreeRTOSRT-Thread

嚴(yán)格來(lái)說(shuō),如果不采用休眠等機(jī)制的話(huà),不管是裸機(jī)還是操作系統(tǒng),CPU使用率都是100%。

為什么這么說(shuō)呢?你看系統(tǒng)的CPU使用率的計(jì)算方法就知道了(這里說(shuō)的是RTOS中簡(jiǎn)單的計(jì)算方式,而不是電腦那種,那種計(jì)算應(yīng)該比較復(fù)雜,魚(yú)鷹也不清楚)。

簡(jiǎn)單的說(shuō),一個(gè)操作系統(tǒng)里有很多用戶(hù)任務(wù),還有一個(gè)特別的系統(tǒng)任務(wù),就是空閑任務(wù)。這個(gè)任務(wù)平時(shí)啥也不敢,就在那里空跑,CPU沒(méi)有其他任務(wù)執(zhí)行的時(shí)候,就會(huì)跑到空閑任務(wù)中執(zhí)行。

除了空跑,空閑任務(wù)還有什么特點(diǎn)??jī)?yōu)先級(jí)最低,不允許掛起空閑任務(wù),即該任務(wù)永遠(yuǎn)處于就緒狀態(tài)。

正因?yàn)檫@些特點(diǎn),它變得非常特殊,也是我們能夠計(jì)算CPU使用率的核心所在。

說(shuō)白了,所謂的CPU使用率計(jì)算,就是先計(jì)算空閑任務(wù)的運(yùn)行時(shí)間,然后反推其他任務(wù)的運(yùn)行時(shí)間。

比如說(shuō),1秒時(shí)間內(nèi),空閑任務(wù)運(yùn)行了700毫秒,那么空閑任務(wù)的CPU使用率是70%,反推一下,其他任務(wù)的使用率就是30%。但是特別注意的是,這里說(shuō)空閑任務(wù)運(yùn)行700毫秒,不是說(shuō)空閑任務(wù)持續(xù)不斷的運(yùn)行了700毫秒,而是中間穿插了其他任務(wù)的執(zhí)行,中間穿插就是300毫秒執(zhí)行其他任務(wù)的時(shí)間。

看這個(gè)圖就清楚了:

計(jì)算CPU使用率的核心所在的內(nèi)容

事實(shí)上,1秒時(shí)間內(nèi)的任務(wù)切換遠(yuǎn)比上圖顯示的要多的多,只是為了更好的說(shuō)明,才沒(méi)畫(huà)那么多切換過(guò)程。

真正好的系統(tǒng),一個(gè)任務(wù)不會(huì)長(zhǎng)時(shí)間占用CPU,而是會(huì)不停的主動(dòng)交出使用權(quán),像上圖任務(wù)2有100毫秒的占用,如果這個(gè)是高優(yōu)先級(jí)任務(wù),那么低優(yōu)先級(jí)的任務(wù)的響應(yīng)肯定在100毫秒以上了。

當(dāng)然,如果說(shuō)這個(gè)響應(yīng)時(shí)間滿(mǎn)足設(shè)計(jì)要求,那么在系統(tǒng)任務(wù)數(shù)比較少的情況下,倒是無(wú)所謂的事情。

可能你還有疑惑,你怎么不說(shuō)說(shuō)空閑任務(wù)啊,空閑任務(wù)有長(zhǎng)達(dá)300毫秒的CPU占用哩!

不好意思,真不需要說(shuō)它,因?yàn)樗膬?yōu)先級(jí)任務(wù)最低,所以如果說(shuō)它能在300毫秒內(nèi)持續(xù)運(yùn)行,那肯定是因?yàn)闆](méi)有其他任務(wù)需要處理才會(huì)讓空閑任務(wù)一直運(yùn)行的。

為什么這么說(shuō)呢?因?yàn)樵诓僮飨到y(tǒng)中,除了主動(dòng)切換任務(wù)外,還有被動(dòng)切換一說(shuō)。

所謂主動(dòng)切換任務(wù),就是任務(wù)本身認(rèn)為自己執(zhí)行完了,然后自己主動(dòng)調(diào)用系統(tǒng)函數(shù)進(jìn)行切換,比如系統(tǒng)延時(shí)函數(shù)等;而被動(dòng)切換有所不同,被動(dòng)切換是時(shí)時(shí)刻刻都在發(fā)生的,只要滿(mǎn)足條件,那么你的任務(wù)可能還沒(méi)有完全執(zhí)行完畢,就可能切換到其他任務(wù)先執(zhí)行了。

怎么理解呢?假如四個(gè)人組成一個(gè)小組討論問(wèn)題,其中一個(gè)是小組長(zhǎng)(操作系統(tǒng)),小組長(zhǎng)有絕對(duì)發(fā)言權(quán),可以隨時(shí)打斷其他成員(任務(wù))的發(fā)言,所以當(dāng)組員發(fā)言時(shí),他每隔幾分鐘都會(huì)檢查一下,看看誰(shuí)舉手準(zhǔn)備發(fā)言,一旦發(fā)現(xiàn)有等級(jí)高的成員舉手,那么不管目前發(fā)言的組員是否發(fā)言完畢,小組長(zhǎng)都會(huì)立刻讓高等級(jí)的組員先發(fā)言,等他發(fā)言完畢,才會(huì)讓之前未發(fā)言完成的組員繼續(xù)發(fā)言。這樣可能不是很人性,但是確實(shí)能保證高效!

計(jì)算CPU使用率的核心所在的內(nèi)容

在上面這張圖中,其實(shí)還有一個(gè)非常重要的東西沒(méi)有畫(huà)出來(lái),那就是操作系統(tǒng)每隔一段時(shí)間對(duì)就緒任務(wù)的檢查。在操作系統(tǒng)中,這種檢查工作一般是由定時(shí)中斷完成的(stm32中有專(zhuān)門(mén)為操作系統(tǒng)準(zhǔn)備的定時(shí)中斷,即SysTick)。

中斷是凌駕于所有任務(wù)(或線(xiàn)程)之上的超級(jí)任務(wù)。

但是檢查時(shí)間(即中斷時(shí)間)也是有講究的,如果檢查時(shí)間過(guò)短,那么整個(gè)系統(tǒng)就會(huì)忙于切換任務(wù),花費(fèi)在任務(wù)切換的時(shí)間占比就會(huì)很大;而檢查時(shí)間過(guò)長(zhǎng),那么高優(yōu)先級(jí)任務(wù)就不能得到更快速的響應(yīng),所以這個(gè)時(shí)間一定要謹(jǐn)慎選擇。

一般來(lái)說(shuō),任務(wù)切換CPU占比在1%以?xún)?nèi)應(yīng)該是比較好的(這個(gè)沒(méi)有理論依據(jù)哈,魚(yú)鷹瞎寫(xiě)的),即如果各個(gè)任務(wù)只調(diào)用一個(gè)延時(shí)函數(shù),如果你的CPU占用在這個(gè)范圍,那么就是比較合適的。

當(dāng)你學(xué)會(huì)了CPU使用率計(jì)算,不如嘗試著修改中斷時(shí)間,你會(huì)發(fā)現(xiàn)不同的中斷時(shí)間,CPU使用情況是不同的,原因就在于操作系統(tǒng)本身的消耗!
責(zé)任編輯:pj

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11015

    瀏覽量

    215366
  • 鼠標(biāo)
    +關(guān)注

    關(guān)注

    6

    文章

    592

    瀏覽量

    40424
  • 管理器
    +關(guān)注

    關(guān)注

    0

    文章

    250

    瀏覽量

    18868
收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    在MR-VMU-RT1176上運(yùn)行的PX4飛行控制軟件的負(fù)載(大約)是多少?

    我想知道在 MR-VMU-RT1176 上運(yùn)行的 PX4 飛行控制軟件的負(fù)載(大約)是多少,包括 RAM 使用率、FLASH 使用率CPU 負(fù)載(可能很難說(shuō)! 我需要通過(guò)以太網(wǎng)和 USB 開(kāi)發(fā)其他任務(wù),因此我想知道添加代碼有多
    發(fā)表于 04-03 06:18

    TECS OpenStack資源池主機(jī)磁盤(pán)分區(qū)使用率過(guò)高的問(wèn)題處理

    某運(yùn)營(yíng)商TECS資源池上報(bào)“主機(jī)磁盤(pán)分區(qū)使用率過(guò)高”的告警,如下圖所示。
    的頭像 發(fā)表于 03-21 09:47 ?314次閱讀
    TECS OpenStack資源池主機(jī)磁盤(pán)分區(qū)<b class='flag-5'>使用率</b>過(guò)高的問(wèn)題處理

    東京物理服務(wù)器的價(jià)格是如何影響用戶(hù)的使用率

    東京物理服務(wù)器的價(jià)格對(duì)用戶(hù)的使用率有顯著影響,主要體現(xiàn)在以下幾個(gè)方面,主機(jī)推薦小編為您整理發(fā)布東京物理服務(wù)器的價(jià)格是如何影響用戶(hù)的使用率
    的頭像 發(fā)表于 02-24 09:16 ?194次閱讀

    云端彈性計(jì)算公式有哪些內(nèi)容

    云端彈性計(jì)算公式有哪些內(nèi)容?云端彈性計(jì)算公式涵蓋資源分配、性能監(jiān)控、自動(dòng)伸縮及積分計(jì)算等方面。資源分配依據(jù)虛擬機(jī)配置和實(shí)際需求動(dòng)態(tài)調(diào)整;性能監(jiān)控實(shí)時(shí)監(jiān)控
    的頭像 發(fā)表于 11-15 11:04 ?420次閱讀

    CPU用率過(guò)高的常見(jiàn)原因

    排查系統(tǒng)問(wèn)題時(shí),CPU 飆升是一個(gè)常見(jiàn)的問(wèn)題。
    的頭像 發(fā)表于 10-23 09:33 ?1338次閱讀

    輕負(fù)載場(chǎng)景下CPU使用率的比較

    Arm Neoverse N 系列和 V 系列處理器并未采用同步多線(xiàn)程 (SMT) 技術(shù)。在 Arm Neoverse 處理器上運(yùn)行時(shí),每個(gè)線(xiàn)程始終能夠訪(fǎng)問(wèn)處理器的全部資源。這有助于提高在云環(huán)境中執(zhí)行的可預(yù)測(cè)性,確保每個(gè)線(xiàn)程都能完全訪(fǎng)問(wèn)處理器資源,并提供更強(qiáng)大的保護(hù),防止線(xiàn)程之間發(fā)生意外數(shù)據(jù)泄露。
    的頭像 發(fā)表于 10-21 09:48 ?697次閱讀
    輕負(fù)載場(chǎng)景下<b class='flag-5'>CPU</b><b class='flag-5'>使用率</b>的比較

    路由器內(nèi)存使用率過(guò)高怎么辦

    路由器內(nèi)存使用率過(guò)高是一個(gè)常見(jiàn)的問(wèn)題,它可能會(huì)導(dǎo)致網(wǎng)絡(luò)速度變慢、連接不穩(wěn)定甚至設(shè)備崩潰。 路由器內(nèi)存的作用和重要性 路由器是網(wǎng)絡(luò)通信的核心設(shè)備,負(fù)責(zé)將數(shù)據(jù)包從一個(gè)網(wǎng)絡(luò)傳輸?shù)搅硪粋€(gè)網(wǎng)絡(luò)。路由器內(nèi)存
    的頭像 發(fā)表于 10-15 14:36 ?2658次閱讀

    路由器內(nèi)存使用率多少算正常

    路由器內(nèi)存使用率的正常范圍取決于多種因素,包括路由器的硬件規(guī)格、網(wǎng)絡(luò)環(huán)境、連接的設(shè)備數(shù)量以及用戶(hù)的具體使用情況。 路由器內(nèi)存使用率概述 路由器是家庭和企業(yè)網(wǎng)絡(luò)中的核心設(shè)備,負(fù)責(zé)數(shù)據(jù)包的轉(zhuǎn)發(fā)和網(wǎng)絡(luò)流量
    的頭像 發(fā)表于 10-15 14:35 ?2012次閱讀

    服務(wù)器cpu用率高怎么解決

    長(zhǎng)時(shí)間運(yùn)行的計(jì)算任務(wù) 應(yīng)用程序存在內(nèi)存泄漏,導(dǎo)致CPU用率上升 系統(tǒng)問(wèn)題 操作系統(tǒng)配置不當(dāng),導(dǎo)致CPU用率高 系統(tǒng)存在病毒或者惡意軟件,
    的頭像 發(fā)表于 10-10 15:14 ?1508次閱讀

    雙核cpu和單核cpu的區(qū)別

    理器核心連接起來(lái),從而提高計(jì)算能力。這種設(shè)計(jì)使得處理器能夠同時(shí)執(zhí)行多個(gè)任務(wù),提高計(jì)算效率和性能。 單核CPU :只有一個(gè)處理器核心,所有的
    的頭像 發(fā)表于 09-24 16:17 ?6105次閱讀

    代理IP的使用率和使用時(shí)長(zhǎng),主要被什么影響?

    代理IP的使用率和使用時(shí)長(zhǎng)受多種因素影響,用戶(hù)需要根據(jù)自己的實(shí)際需求和場(chǎng)景選擇合適的代理類(lèi)型和策略。同時(shí),注意監(jiān)控代理IP的使用情況,及時(shí)調(diào)整和優(yōu)化使用策略,以提高代理IP的利用率和使用時(shí)長(zhǎng)。以上就是今日分享的所有內(nèi)容了,感謝您
    的頭像 發(fā)表于 09-18 08:14 ?439次閱讀
    代理IP的<b class='flag-5'>使用率</b>和使用時(shí)長(zhǎng),主要被什么影響?

    CPU的定義和功能

    CPU(Central Processing Unit,中央處理器)作為計(jì)算機(jī)系統(tǒng)的核心部件,其功能和作用至關(guān)重要。以下是對(duì)CPU功能的詳細(xì)解析,內(nèi)
    的頭像 發(fā)表于 09-10 11:45 ?9721次閱讀

    JAVA應(yīng)用CPU跳點(diǎn)自動(dòng)DUMP工具

    背景 在做系統(tǒng)監(jiān)控時(shí),CPU使用率是一個(gè)關(guān)鍵的指標(biāo),它反映了系統(tǒng)的性能穩(wěn)定性以及是否存在異常情況,能幫助我們了解系統(tǒng)的負(fù)載情況。通過(guò)監(jiān)控CPU使用率,可以判斷系統(tǒng)是否正常運(yùn)行或者是否
    的頭像 發(fā)表于 08-05 17:48 ?665次閱讀

    蘋(píng)果Vision Pro使用率低引關(guān)注

    近日,科技界傳來(lái)一則令人矚目的消息。天風(fēng)國(guó)際證券的分析師郭明錤在社交平臺(tái)上指出,根據(jù)他的觀察,許多用戶(hù)在購(gòu)買(mǎi)蘋(píng)果最新推出的Vision Pro頭顯后,其實(shí)際使用率并不高,不少用戶(hù)在簡(jiǎn)單嘗試幾次后便
    的頭像 發(fā)表于 06-22 11:47 ?1140次閱讀

    恒訊科技全面解析:如何有效降低服務(wù)器CPU用率

    降低服務(wù)器CPU用率是一個(gè)涉及監(jiān)控、診斷和優(yōu)化的全面過(guò)程。以下是一些有效的方法: 1、監(jiān)控CPU使用率: 使用工具如top, htop, vmstat, 或 iostat實(shí)時(shí)監(jiān)控
    的頭像 發(fā)表于 05-10 17:24 ?977次閱讀
    主站蜘蛛池模板: 国产高清在线观看 | h视频在线播放 | 国产一区二卡三区四区 | 一二三四日本视频社区 | 国产老头和美女在线观看 | 一级做α爰片久久毛片 | 日本aaaaa级毛片片 | 福利午夜在线 | 97干干 | 男女全黄做爰视频 | 国产三级一区 | 免费一级毛毛片 | 天天爽天天狼久久久综合 | 在线播放视频网站 | 日本免费大黄在线观看 | 免费观看黄色网页 | 大量喷潮free | 99 久久99久久精品免观看 | 护士巨好爽好大乳 | 美女喷白浆 | 国产色妞妞在线观看 | 最近最新免费视频 | bt天堂在线www种子搜索 | 在线色色视频 | 国产福利久久 | 黄色的视频在线免费观看 | 国产亚洲美女精品久久久久狼 | 国产在线一区二区三区四区 | 久久精品人人爽人人爽 | 亚洲综合丁香 | 天天摸天天插 | 激情五月宗合网 | caoporn97人人做人人爱最新 | 国产老头和美女在线观看 | 欧美一级高清免费a | 四虎影院观看视频 | 欧美成网站 | 欧美 亚洲 国产 丝袜 在线 | 亚洲欧美在线观看 | 亚洲二区视频 | 天天干天天干 |