日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuà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 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

看這個圖就清楚了:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    關注

    68

    文章

    11332

    瀏覽量

    225994
  • 鼠標
    +關注

    關注

    6

    文章

    599

    瀏覽量

    41913
  • 管理器
    +關注

    關注

    0

    文章

    265

    瀏覽量

    19558
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    ASPICE 3.1 與 4.0 版本的核心差異:從軟件專屬到全系統(tǒng)覆蓋(四)

    AI 密集型場景的研發(fā)需求; 2.新增 VAL 驗證過程組,完善了系統(tǒng)級驗證的過程規(guī)范,填補了 3.1 版本在產(chǎn)品最終驗證環(huán)節(jié)的規(guī)范空白; 3.精簡冗余過程,刪除了 10 個行業(yè)使用率極低、內(nèi)容
    發(fā)表于 04-08 09:48

    基于Arm架構服務器釋放更高CPU用率

    在大型云服務提供商的數(shù)據(jù)中心中,CPU用率長期偏低,造成了大量資源閑置。根據(jù) CAST AI 的分析,超過 1,000 個 CPU 的大型集群平均占用率僅約 17%[1],不同云服
    的頭像 發(fā)表于 03-24 10:19 ?574次閱讀

    MAX1544:AMD Hammer CPU核心電源的雙相快速PWM控制器

    MAX1544:AMD Hammer CPU核心電源的雙相快速PWM控制器 在電子設備的電源管理領域,為特定CPU設計高效、穩(wěn)定的電源供應方案是至關重要的。今天,我們就來深入探討一款專為AMD
    的頭像 發(fā)表于 03-17 15:05 ?181次閱讀

    深入解析MAX17582:IMVP - 6.5 CPU核心電源的理想之選

    深入解析MAX17582:IMVP - 6.5 CPU核心電源的理想之選 在當今電子設備飛速發(fā)展的時代,CPU性能不斷提升,對其核心電源的要求也越來越高。MAX17582作為一款專為I
    的頭像 發(fā)表于 03-17 14:30 ?158次閱讀

    深入解析MAX17410:IMVP6+ CPU核心電源的理想控制器

    深入解析MAX17410:IMVP6+ CPU核心電源的理想控制器 在當今的電子設備中,CPU的性能不斷提升,對電源的要求也越來越高。對于筆記本電腦等設備的IMVP6+ CPU
    的頭像 發(fā)表于 03-17 14:30 ?174次閱讀

    為何CPU是AI基礎設施的核心

    人工智能 (AI) 并非一種具有單一理想基礎設施的單一工作負載。AI 涵蓋了多樣化的工作負載,需要系統(tǒng)層面的協(xié)同策略,才能高效且可擴展地提供性能。而在這一策略中,CPU 扮演著核心角色,它作為系統(tǒng)的智能層,統(tǒng)籌協(xié)調(diào)云端、數(shù)據(jù)中心、邊緣乃至新興物理 AI 系統(tǒng)中的各類
    的頭像 發(fā)表于 03-11 10:35 ?1389次閱讀

    Typecho博客搭建與公網(wǎng)訪問指南

    、 Typecho采用GPL v2開源協(xié)議,基于PHP5+開發(fā),支持MySQL、PostgreSQL和SQLite等多種數(shù)據(jù)庫。其核心優(yōu)勢包括: a) 輕量高效:CPU和內(nèi)存使用率極低 b) 原生
    的頭像 發(fā)表于 12-26 17:13 ?891次閱讀
    Typecho博客搭建與公網(wǎng)訪問指南

    H110主板CPU PWM芯片ISL95858HRZ-T核心供電電路圖資料

    技嘉H110主板CPU PWM芯片ISL95858HRZ-T核心、核顯供電電路圖
    發(fā)表于 12-10 14:44 ?10次下載

    ATK_XCM.exe是什么?

    這是一張計算機硬件監(jiān)控系統(tǒng)界面的截圖,主要用于實時顯示設備的核心硬件狀態(tài)及提供基礎操作功能。以下是具體內(nèi)容解析: 核心功能分區(qū) 硬件狀態(tài)監(jiān)測區(qū)(表格部分) 項目 說明
    發(fā)表于 10-24 09:37

    CPU 到 GPU,渲染技術如何重塑游戲、影視與設計?

    渲染技術是計算機圖形學的核心內(nèi)容之一,它是將三維場景轉換為二維圖像的過程。渲染技術一直在不斷演進,從最初的CPU渲染到后來的GPU渲染,性能和質(zhì)量都有了顯著提升。從CPU到GPU:技術
    的頭像 發(fā)表于 09-01 12:16 ?1161次閱讀
    從 <b class='flag-5'>CPU</b> 到 GPU,渲染技術如何重塑游戲、影視與設計?

    探索CPU架構的奧秘,揭秘高性能計算的隱形引擎

    的深海,揭開那些隱藏在高性能計算背后的神秘面紗。1.取指令(Fetch)程序計數(shù)器(PC):CPU通過程序計數(shù)器獲取下一條指令的內(nèi)存地址。指令讀?。簭拇鎯ζ骰蚓彺嬷凶x
    的頭像 發(fā)表于 08-13 11:58 ?985次閱讀
    探索<b class='flag-5'>CPU</b>架構的奧秘,揭秘高性能<b class='flag-5'>計算</b>的隱形引擎

    單核CPU網(wǎng)關和雙核CPU網(wǎng)關有什么區(qū)別

    單核CPU網(wǎng)關與雙核CPU網(wǎng)關的核心區(qū)別在于處理能力、多任務效率、性能表現(xiàn)及適用場景,雙核CPU網(wǎng)關在多任務處理、復雜計算和響應速度上具有顯
    的頭像 發(fā)表于 07-05 14:37 ?1349次閱讀

    智能安防邊緣計算的技術解析

    維度,剖析核心板如何推動安防從"被動記錄"到"主動決策"的升級,并給出選型建議。 ? --- 一、核心板的硬件架構創(chuàng)新** ? 1. 異構計算架構:算力與能效的平衡? 以SSD2351為例,其采用**"
    的頭像 發(fā)表于 06-26 11:56 ?802次閱讀

    飛凌嵌入式ElfBoard ELF 1板卡-文件系統(tǒng)常用命令之磁盤管理與維護常用命令

    使用的磁盤空間;Available:剩余可用的磁盤空間大?。籙se%:磁盤的使用率使用率過高時,需要注意,因空間不足造成系統(tǒng)問題。/dev/root 為文件系統(tǒng)根目錄。當Use% 高達90%以上
    發(fā)表于 06-24 11:26

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

    邊緣計算網(wǎng)關是一種部署在網(wǎng)絡邊緣的智能設備,通過集成計算、存儲、通信和協(xié)議轉換能力,實現(xiàn)數(shù)據(jù)的本地化處理與分析。其核心價值在于: 降低延遲:在數(shù)據(jù)源附近完成計算,避免云端傳輸帶來的時延
    的頭像 發(fā)表于 05-21 09:13 ?1223次閱讀
    璧山县| 嘉黎县| 泸定县| 郁南县| 顺平县| 金阳县| 陇南市| 吐鲁番市| 大庆市| 汾西县| 招远市| 龙海市| 金乡县| 沙洋县| 车险| 台南市| 安仁县| 额济纳旗| 类乌齐县| 五大连池市| 依兰县| 雅安市| 边坝县| 濮阳市| 攀枝花市| 疏勒县| 莱芜市| 威信县| 灵武市| 大连市| 阳西县| 平南县| 泸西县| 唐海县| 曲周县| 明星| 华容县| 抚顺县| 汉阴县| 厦门市| 漯河市|