www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 公眾號精選 > 程序喵大人
[導(dǎo)讀]在前面文章中,我們介紹了實時性的基本模型、并分析了實時性窗口內(nèi)不同位置的時間對整個系統(tǒng)的價值,得出了一個結(jié)論——實時性窗口中越靠前的時間對系統(tǒng)中的其它任務(wù)越有價值;當(dāng)一個有實時性要求的事件發(fā)生時,如果“不顧其它任務(wù)、自私自利”—— 只“ 單純 ”考慮以越快越好的速度盡快完成當(dāng)前的事件處理,會給整個系統(tǒng)的實時性帶來毀滅性的結(jié)果——事實上,當(dāng)所有任務(wù)都采取這一策略時,系統(tǒng)中沒有任何一個任務(wù)的實時性是可以確定得到保證的。

【說在前面的話】


在前面文章中,我們介紹了實時性的基本模型、并分析了實時性窗口內(nèi)不同位置的時間對整個系統(tǒng)的價值,得出了一個結(jié)論—— 實時性窗口中越靠前的時間對系統(tǒng)中的其它任務(wù)越有價值;當(dāng)一個有實時性要求的事件發(fā)生時,如果“不顧其它任務(wù)、自私自利”—— 只“ 單純 ”考慮以越快越好的速度盡快完成當(dāng)前的事件處理,會給整個系統(tǒng)的實時性帶來毀滅性的結(jié)果——事實上,當(dāng)所有任務(wù)都采取這一策略時,系統(tǒng)中沒有任何一個任務(wù)的實時性是可以確定得到保證的。關(guān)于以上的結(jié)論,如果你還沒有閱讀過前一篇文章、或是對上述結(jié)論仍然抱有疑惑,可以單擊 《實時性迷思(1)——”快是優(yōu)點么“?》進(jìn)行閱讀。
究竟時間片輪轉(zhuǎn)能不能確保實時性?相信在閱讀完本文以后,你一定可以做出自己的判斷。也歡迎將你的想法在評論區(qū)留言。

【正文】


在討論系統(tǒng)實時性的問題時,我們常常會跳過一個非常重要的步驟——證明當(dāng)前系統(tǒng)在理論上是否有解——而直接進(jìn)入討論“如何確保具體任務(wù)實時性的方法”中來。這就好比看到一個渾濁的池塘,首先不調(diào)查是否可能有魚,而直接開始著手釣魚一樣——也許大概率有魚而你又運氣不錯,皆大歡喜;又或者根本污染嚴(yán)重魚早就缺氧死光了,你卻以為是自己運氣不好,或者是技術(shù)不佳,悻悻而歸——這實在是太可笑了。

那么,讓我們明確一下這里首先需要面對和解決的問題吧:
  • 在一個多任務(wù)系統(tǒng)中,有一部分(或者全部)任務(wù)擁有實時性要求;

  • 對于這些有實時性要求的任務(wù)來說,任何一個任務(wù)在任何一種情形、哪怕是極小的概率下、存在無法滿足實時性的可能,整個系統(tǒng)就判定為無法滿足實時性要求;

  • 由于上述判定條件過于苛刻,所以工程實踐中,我們一般退而求其次,轉(zhuǎn)而尋找一定無法滿足實時性的情況,即:

    • 如果在極其理想的條件下,可以通過數(shù)學(xué)方法證明這些任務(wù)的實時性一定無法得到滿足,則需要調(diào)整硬件環(huán)境,或者對任務(wù)進(jìn)行重新規(guī)劃、降低實時性要求;

    • 如果在極其理想的條件下,證明系統(tǒng)的實時性可以得到保證,則我們只能假設(shè)可能存在一種方式讓當(dāng)前系統(tǒng)的實時性得到保證——此時我們可以進(jìn)入下一階段的討論——也就是如何設(shè)計系統(tǒng)、將理論上證明可能做的事情變成既成事實。


如果上面的描述讓你摸不著北,其實也可以換一種簡單的說法:
  • 如果數(shù)學(xué)上都已經(jīng)能證明實時性得不到保證了,咱們就別折騰了;

  • 如果數(shù)學(xué)上證明有希望,咱們再繼續(xù)討論實施方法——究竟最終能不能做到——事在人為,結(jié)果另說。


那么這是個怎樣的數(shù)學(xué)模型呢?請大家翻出小學(xué)課本,學(xué)過除法和百分?jǐn)?shù)的那個年級就行:

先說結(jié)論:

  • 我們就是要計算每個實時性任務(wù)可能占用的最大CPU資源,并用百分比表示;

  • 計算所有實時性任務(wù)所占用CPU資源的總和(將百分比累加起來)

    • 如果超過100%,則整個實時性必然得不到保證;

    • 如果沒有超過100%,則可以判定在理想狀況下,系統(tǒng)的實時性是有可能得到保證的;

  • 實踐中,距離100%越遠(yuǎn),則可能性越大。如果卡著100%或者99%則相當(dāng)危險,甚至可以穩(wěn)妥的判定為不滿足。


怎么樣?道理是不是很簡單?那么具體怎么計算呢?


  • 觀察此前介紹的實時性模型可以發(fā)現(xiàn),無論是“實時性窗口”,還是“處理事件所需的時間”?都是表示時間長短的量;

  • 其中,“實時性窗口” 是根據(jù)具體應(yīng)用需要,由自于客觀物理世界的時間要求所決定的,翻譯成人話就是:“如果不在某一時間內(nèi)完成任務(wù),就會受到牛頓的毒打!”


  • 實時性窗口還隱含了另外一個重要的假設(shè),即,最差情況下,這個事件可能會以實時性窗口所代表的時間間(Interval, Period)隔周期性的發(fā)生——正可謂一波剛平一波又起(紳士們,我就不配圖了)。

  • 事件處理所需時間”,故名思意,就是CPU執(zhí)行事件處理程序所需的時間。這里其實涉及到另外一個非常關(guān)鍵的問題——確定性(Deterministic):說白了,就是“最起碼”要你能夠拍胸脯打包票——執(zhí)行這個任務(wù)所花的時間存在一個最大值(上界),并且這個上界是穩(wěn)定可靠的——這只是確定性的最低標(biāo)準(zhǔn);有時候某些應(yīng)用對確定性的要求高的乍舌,比如,系統(tǒng)會強硬的規(guī)定:執(zhí)行時間只允許在某一個非常小的范圍內(nèi)微弱的波動,做不到就直接判定為不滿足“確定性”要求(例如很多車載系統(tǒng)中所使用的ECU就是這樣),從而整個系統(tǒng)的實時性也成了空中樓閣。



為什么確定性如此重要呢?你想一想,如果一個滿口跑火車的人跟你做了個保證:“明天股市一定暴漲,你趕快滿倉”,你真敢根據(jù)這樣的信息來做決策么?
在實時性系統(tǒng)中,任務(wù)執(zhí)行時間是一個非常關(guān)鍵的指標(biāo),它直接關(guān)系到任務(wù)實際占用系統(tǒng)資源的百分比,如果這個數(shù)據(jù)不是“確定的”,我們又如何“確定的說”:系統(tǒng)一定能滿足實時性要求呢?
這里有一個很重要的結(jié)論,大家可以拿小本本記下來:

實時性 不一定 要求系統(tǒng)跑的越快越好,但 一定 要求系統(tǒng)是具有高度確定性的。

這就是為什么,低頻率低性能的Cortex-M和高頻率高性能的Cortex-R都能用于實時系統(tǒng);而高頻率高性能的 Cortex-A卻無法滿足“硬實時”的要求 (因為Cortex-A使用MMU,理論上由實現(xiàn)虛擬地址空間導(dǎo)致的存儲器訪問時間是不確定的,因此建立在MMU基礎(chǔ)上的任務(wù)執(zhí)行就是無法滿足確定性要求的)。


  • 值得強調(diào)的是,假設(shè)事件處理程序的代碼是一樣的,那么很容易理解:當(dāng)CPU頻率升高的時候(CPU單位時間內(nèi)可以執(zhí)行的指令增加的時候),事件處理所需的時間就越短

基于以上事實,我們可以設(shè)想一個嚴(yán)格的理想狀況:

  • 某個事件已“實時性窗口”所表示的時間間隔(Tw)周期性的發(fā)生;

  • 在這個周期內(nèi),要消耗時間(Th)來處理這個事件

則當(dāng)前實時性任務(wù)所消耗的CPU資源百分比為:

這里的

就是“事件n”的CPU資源占用。


【反復(fù)橫跳的代價】


  不知道你還記不記得本文一開始我們試圖討論的那個問題:即,時間片輪轉(zhuǎn)是否對實時性的保證有意義?經(jīng)過前面的理論準(zhǔn)備,我們現(xiàn)在就有了明確而清晰回答這個問題所需的所有條件:


已知的事實如下:


  • CPU頻率不變的情況下,CPU的可用資源是固定的

  • 實現(xiàn)時間片輪轉(zhuǎn)的方法有多種多樣:比如,純粹的合作式輪轉(zhuǎn)(諸如裸機中的switch狀態(tài)機,或者是基于函數(shù)指針的合作式調(diào)度器);又或是操作系統(tǒng)下,擁有相同優(yōu)先級任務(wù)間所使用的可搶占式時間片輪詢,即Round-roubin模式(詳情請參考《【解惑】到底是“時間片”還是“分時輪詢”?》)。

  • 無論采用哪種時間片輪轉(zhuǎn)方式,任務(wù)的切換都是有代價的。比如,裸機中,進(jìn)出函數(shù)所需的跳轉(zhuǎn)代價、局部變量在棧中重建的代價(詳情參考《漫談C變量——夏蟲不可語冰》);操作系統(tǒng)中任務(wù)調(diào)度的代價等等。

  • 在存量是固定不變的前提下,任務(wù)切換越頻繁,則切換所消耗的CPU時間就越多,因此實際用于實時性任務(wù)處理的CPU資源就越少




結(jié)論:頻繁任務(wù)切換對系統(tǒng)實時性是有害的;由于頻繁時間片輪轉(zhuǎn)會導(dǎo)致大量不必要的任務(wù)切換,因此對實時性總體上來說是有害的


推論:任務(wù)切換對實時性系統(tǒng)來說是必要的,但一定要越少越好——拒絕花拳繡腿的反復(fù)橫跳,只做真正有必要的任務(wù)切換。


很不客氣的說,很多人一直把并發(fā)、甚至(僅僅只是并發(fā) 其中一種 實現(xiàn)方式的)“時間片輪轉(zhuǎn)”當(dāng)成“確保實時性的沙子”——不僅一頭扎進(jìn)去而不自知,還對周圍的人傳授自己的成功經(jīng)驗——實在是讓人扼腕嘆息。


【結(jié)語】


  本文的結(jié)論實際上從本質(zhì)上傳達(dá)了一個信息:無論是裸機還是操作系統(tǒng)環(huán)境,多任務(wù)都是可以實現(xiàn)的——這是并發(fā)技術(shù)的本質(zhì)所決定的。時間片輪轉(zhuǎn)只是裸機和操作系統(tǒng)環(huán)境下常見的、“無腦”實現(xiàn)并發(fā)的一種方式——或者說,時間片輪轉(zhuǎn)的作用只是實現(xiàn)并發(fā)而已,它不僅與實時性的保證無關(guān),甚至是有害的。

  那么,假設(shè),在通過數(shù)學(xué)方式證明了:“可能存在一種解來滿足系統(tǒng)的實時性要求”,那么具體有什么方法能夠?qū)崿F(xiàn)它呢?欲知詳情,請聽下回分解。

往期推薦






免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉