深入探討RTOS任務(wù)調(diào)度與多任務(wù)
RTOS中協(xié)程與任務(wù)的主要區(qū)別體現(xiàn)在資源占用、調(diào)度方式及實(shí)現(xiàn)機(jī)制上:
資源占用
?任務(wù)?:每個(gè)任務(wù)需獨(dú)立分配堆??臻g、堆空間及任務(wù)控制塊,資源占用較大。 ?
?協(xié)程?:所有協(xié)程共享同一線程的堆??臻g,僅需少量內(nèi)存存儲(chǔ)局部變量和狀態(tài),顯著減少RAM使用。 ?
調(diào)度方式
?任務(wù)?:由RTOS調(diào)度器自動(dòng)管理,涉及上下文切換和內(nèi)核干預(yù)。 ?
?協(xié)程?:由用戶代碼顯式控制(如調(diào)用crDELAY),無需操作系統(tǒng)介入,靈活性更高。 ?
實(shí)現(xiàn)機(jī)制
?任務(wù)?:支持搶占式優(yōu)先級(jí)調(diào)度,適用于復(fù)雜系統(tǒng)。 ?
?協(xié)程?:通過宏定義實(shí)現(xiàn),僅在單線程內(nèi)運(yùn)行,適合內(nèi)存受限的嵌入式系統(tǒng)。 ?
適用場景
?任務(wù)?:適用于需要高可靠性和復(fù)雜任務(wù)管理的系統(tǒng)。 ?
?協(xié)程?:適合資源受限的場景(如8/16位MCU),可減少系統(tǒng)開銷。
01RTOS中的協(xié)程概述在RTOS系統(tǒng)中,除了我們熟悉的進(jìn)程和線程(在RTOS中通常被稱為任務(wù)),還存在著另一種程序模型——協(xié)程。協(xié)程,作為協(xié)同程序的簡稱,英文名Coroutine,以其更輕量級(jí)的特性在并發(fā)編程領(lǐng)域占據(jù)了一席之地。它允許在單個(gè)線程內(nèi)高效執(zhí)行多個(gè)協(xié)程,這些協(xié)程能夠靈活地掛起與恢復(fù),從而實(shí)現(xiàn)了高效的并發(fā)執(zhí)行。接下來,我們將深入探討RTOS中協(xié)程與任務(wù)的內(nèi)容,并剖析它們的異同。
◇ 協(xié)程的三種狀態(tài)
協(xié)程在RTOS中主要呈現(xiàn)為三種狀態(tài):運(yùn)行、就緒和阻塞。這些狀態(tài)相互轉(zhuǎn)換,共同構(gòu)成了協(xié)程在RTOS中的執(zhí)行模型。
運(yùn)行狀態(tài):當(dāng)協(xié)程正在執(zhí)行時(shí),它被稱為處于運(yùn)行狀態(tài),此時(shí)處理器正被當(dāng)前協(xié)程所使用。
就緒狀態(tài):就緒的協(xié)程是那些已經(jīng)準(zhǔn)備好執(zhí)行(未被阻塞)但當(dāng)前尚未執(zhí)行的協(xié)程。
阻塞狀態(tài):若協(xié)程當(dāng)前正處于等待時(shí)間事件或外部事件的狀態(tài),則該協(xié)程被視為處于阻塞狀態(tài)。
◇ 協(xié)程與任務(wù)的區(qū)別
盡管協(xié)程與RTOS中的任務(wù)在某些方面相似,但它們之間也存在諸多差異。協(xié)程在輕量級(jí)和不需系統(tǒng)調(diào)度器介入方面有顯著不同,靈活性更高。協(xié)程函數(shù)以crSTART開始,并以crEND結(jié)束,且該函數(shù)不應(yīng)返回任何值。
從裸機(jī)到RTOS的轉(zhuǎn)型,對于許多嵌入式開發(fā)者來說,確實(shí)是一個(gè)充滿挑戰(zhàn)的階段。這個(gè)過程中,他們可能會(huì)遇到諸如臨界段、調(diào)度、信號(hào)量和互斥鎖等復(fù)雜概念,這些概念對于初學(xué)者來說往往讓人感到困惑。然而,通過深入了解和掌握這些核心概念,他們將能夠更好地理解RTOS的多任務(wù)調(diào)度機(jī)制。
? 多任務(wù)與調(diào)度器
多任務(wù),相較于裸機(jī)系統(tǒng)的單任務(wù)或輪詢模式,意味著系統(tǒng)能夠同時(shí)處理多個(gè)任務(wù)。在RTOS中,這些任務(wù)通過調(diào)度器進(jìn)行高效管理,確保每個(gè)任務(wù)都能得到及時(shí)的響應(yīng)和處理。通過引入信號(hào)量和互斥鎖等同步機(jī)制,RTOS能夠有效地解決多任務(wù)環(huán)境下的資源競爭和同步問題,從而提升系統(tǒng)的整體性能和響應(yīng)速度
? 信號(hào)量與互斥鎖
了解多任務(wù)調(diào)度的原理和應(yīng)用,對于嵌入式開發(fā)者來說至關(guān)重要。它不僅能夠幫助他們更好地應(yīng)對RTOS帶來的挑戰(zhàn),還能夠提升他們的開發(fā)效率和系統(tǒng)穩(wěn)定性。因此,掌握多任務(wù)調(diào)度的核心概念和技巧,是每一個(gè)嵌入式開發(fā)者不可或缺的技能。
02多任務(wù)調(diào)度的原理與應(yīng)用? 多任務(wù)定義與實(shí)現(xiàn)
那么,多任務(wù)究竟是什么呢?在多任務(wù)操作系統(tǒng)中,通過特定的任務(wù)調(diào)度策略,兩個(gè)或更多進(jìn)程能夠并發(fā)地共享一個(gè)處理器。但需要注意的是,在任意時(shí)刻,處理器僅會(huì)為一件任務(wù)提供服務(wù)。由于任務(wù)調(diào)度機(jī)制的高效性,不同任務(wù)之間的切換速度非常快,從而產(chǎn)生了多個(gè)任務(wù)同時(shí)運(yùn)行的錯(cuò)覺。
對于初學(xué)者來說,可以這樣理解:多任務(wù)系統(tǒng)類似于我們之前提到的多個(gè)輪詢系統(tǒng)。在代碼層面,我們可以將一個(gè)大while循環(huán)中的多項(xiàng)任務(wù)拆分成幾個(gè)小任務(wù),分別進(jìn)行處理。這樣,每個(gè)任務(wù)都能得到有序且高效的處理,從而提升了系統(tǒng)的整體性能和響應(yīng)速度。
? 任務(wù)切換與效率
在多任務(wù)處理中,各個(gè)任務(wù)之間的切換與調(diào)度是不可或缺的環(huán)節(jié)。然而,這種切換是否會(huì)占用大量CPU時(shí)間,從而影響任務(wù)執(zhí)行效率呢?這曾經(jīng)是我初學(xué)RTOS時(shí)的困惑。當(dāng)時(shí),我誤以為在滴答設(shè)置1000(即1ms時(shí)間)的情況下,CPU在各個(gè)任務(wù)間頻繁切換會(huì)消耗大量資源。
事實(shí)上,我那時(shí)對處理器能力的估計(jì)過于保守。以STM32F103運(yùn)行72M為例,每1ms內(nèi)能執(zhí)行的代碼量是相當(dāng)可觀的。深入思考后,我們會(huì)發(fā)現(xiàn),任務(wù)切換所需的幾行代碼在CPU的高速處理能力下,其所需時(shí)間幾乎可以忽略不計(jì)。當(dāng)然,這主要是針對高速處理器而言。對于低頻處理器,這個(gè)時(shí)間可能相對較長,但即便如此,任務(wù)調(diào)度仍然是一種高效的任務(wù)管理方式。
? 占搶調(diào)度與輪詢調(diào)度
任務(wù)調(diào)度可分為搶占調(diào)度和輪詢調(diào)度兩種方式。在實(shí)時(shí)操作系統(tǒng)(RTOS)中,為了確保任務(wù)能夠獲得及時(shí)的響應(yīng),通常采用搶占調(diào)度策略。以UCOS為例,它就是一種典型的搶占式調(diào)度系統(tǒng)。
在程序執(zhí)行過程中,一旦出現(xiàn)高優(yōu)先級(jí)任務(wù),它將會(huì)打斷當(dāng)前正在執(zhí)行的低優(yōu)先級(jí)任務(wù)。這種打斷會(huì)持續(xù)到高優(yōu)先級(jí)任務(wù)執(zhí)行完畢,之后低優(yōu)先級(jí)任務(wù)才會(huì)重新獲得執(zhí)行機(jī)會(huì)。然而,有人可能會(huì)提出疑問:如果高優(yōu)先級(jí)任務(wù)長時(shí)間持續(xù)執(zhí)行,這種情況是否可行?
事實(shí)上,這涉及到了任務(wù)優(yōu)先級(jí)的合理分配以及任務(wù)設(shè)計(jì)的考量。通常,高優(yōu)先級(jí)任務(wù)被設(shè)計(jì)為響應(yīng)某種緊急事件,執(zhí)行一些既緊急又不耗時(shí)的操作。而對于那些耗時(shí)較長的任務(wù),則通常被賦予較低的優(yōu)先級(jí),在系統(tǒng)負(fù)載較輕時(shí)逐步處理。