女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

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

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

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

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

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

為什么要知道這個呢?知道這個有啥用呢?魚鷹看的書少,就不寫官方話了,只說說自己的理解。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

正因為這些特點,它變得非常特殊,也是我們能夠計算CPU使用率的核心所在。

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

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

看這個圖就清楚了:

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

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

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

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

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

不好意思,真不需要說它,因為它的優(yōu)先級任務(wù)最低,所以如果說它能在300毫秒內(nèi)持續(xù)運(yùn)行,那肯定是因為沒有其他任務(wù)需要處理才會讓空閑任務(wù)一直運(yùn)行的。

為什么這么說呢?因為在操作系統(tǒng)中,除了主動切換任務(wù)外,還有被動切換一說。

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

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

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

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

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

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

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

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

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

    關(guān)注

    68

    文章

    11052

    瀏覽量

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

    關(guān)注

    6

    文章

    593

    瀏覽量

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

    關(guān)注

    0

    文章

    252

    瀏覽量

    18968
收藏 人收藏

    評論

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

    邊緣計算網(wǎng)關(guān):定義與核心價值

    邊緣計算網(wǎng)關(guān)是一種部署在網(wǎng)絡(luò)邊緣的智能設(shè)備,通過集成計算、存儲、通信和協(xié)議轉(zhuǎn)換能力,實現(xiàn)數(shù)據(jù)的本地化處理與分析。其核心價值在于: 降低延遲:在數(shù)據(jù)源附近完成計算,避免云端傳輸帶來的時延
    的頭像 發(fā)表于 05-21 09:13 ?154次閱讀

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

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

    TECS OpenStack資源池主機(jī)磁盤分區(qū)使用率過高的問題處理

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

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

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

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

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

    CPU用率過高的常見原因

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

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

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

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

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

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

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

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

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

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

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

    代理IP的使用率和使用時長,主要被什么影響?

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

    CPU的定義和功能

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

    JAVA應(yīng)用CPU跳點自動DUMP工具

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

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

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