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

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

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

任務(wù)狀態(tài)機(jī)的相關(guān)概念

玩轉(zhuǎn)嵌入式 ? 來源:嵌入式客棧 ? 2023-11-13 09:39 ? 次閱讀

[導(dǎo)讀] 大家好,我是逸珺。

前面一文利用FreeRTOS點(diǎn)燈,算是將FreeRTOS給跑起來了,要用好RTOS,從黑盒角度去理解一下調(diào)度器是怎么工作的是很必要的,當(dāng)然如果想研究其內(nèi)部實(shí)現(xiàn)原理,可以去讀其內(nèi)部實(shí)現(xiàn)代碼,但是個(gè)人感覺如果是從用的角度,把內(nèi)核看成黑盒,跳出來梳理一下概念也很有用。

所以本文不切入內(nèi)核代碼,僅從用戶視角來學(xué)習(xí)一下任務(wù)狀態(tài)機(jī)相關(guān)的概念,以及相應(yīng)API的作用。

RTOS核的作用

前面一文分析FreeRTOS框架的時(shí)候,曾給出這樣一個(gè)理解圖:

41930b1e-81c2-11ee-939d-92fbcf53809c.png

對(duì)于單片機(jī)而言,一般只有一個(gè)核,RTOS的主要作用是將用戶多任務(wù)進(jìn)行管理,在物理CPU核上調(diào)度管理。所以為了方便理解,可以將RTOS的調(diào)度管理器,看成是將硬件CPU核通過軟件的辦法為每一個(gè)應(yīng)用任務(wù)虛擬出一個(gè)軟核。這樣就使每個(gè)任務(wù)看起來都擁有一個(gè)CPU核,這樣從時(shí)間維度上看起來多任務(wù)是并行的,而事實(shí)上這種并行是偽并行。

一般單片機(jī)只有一個(gè)硬件核,那么在任意時(shí)刻,則只可能有一個(gè)任務(wù)在運(yùn)行。其實(shí)這樣理解還不全面,能夠獲取CPU時(shí)間的,從應(yīng)用編程的視角,還有一個(gè)主角是不能忽略的,那就是中斷程序。

41ac5aba-81c2-11ee-939d-92fbcf53809c.png

任務(wù)狀態(tài)

狀態(tài)概念

對(duì)于FreeRTOS的狀態(tài)概念有必要先好好理解一下,理解了才能正確的使用API進(jìn)行正確的應(yīng)用,才知道調(diào)用了某一個(gè)API究竟會(huì)有怎樣的行為表現(xiàn)。

<>在任務(wù)管理章節(jié),首先給出任務(wù)的一個(gè)頂層狀態(tài)機(jī)視圖:

41c31a7a-81c2-11ee-939d-92fbcf53809c.png

對(duì)于單內(nèi)核的芯片而言,任一任務(wù)要么處于運(yùn)行態(tài),要么處于非運(yùn)行態(tài)。但同一時(shí)刻只能有一個(gè)任務(wù)處于運(yùn)行態(tài)。這也是為什么這個(gè)圖中①畫的任務(wù)框是多個(gè)疊起來的,而②所示的任務(wù)只有一個(gè)框的原因。那么事實(shí)上,對(duì)于非運(yùn)行態(tài)其內(nèi)部又被劃分出了幾個(gè)子狀態(tài):

41d93ca6-81c2-11ee-939d-92fbcf53809c.png

Suspended: 掛起態(tài),什么叫掛起呢?簡(jiǎn)單講就是任務(wù)進(jìn)入了掛起態(tài)后,調(diào)度器就不會(huì)對(duì)其進(jìn)行調(diào)度了,也就是它不會(huì)被調(diào)度器裝載到CPU核中運(yùn)行,任務(wù)狀態(tài)始終保持在進(jìn)入掛起態(tài)時(shí)刻的現(xiàn)場(chǎng)。

就好比看一個(gè)修仙劇,內(nèi)核調(diào)度器是一個(gè)法術(shù)高手,會(huì)時(shí)間靜止法術(shù),啪一個(gè)法術(shù),這個(gè)任務(wù)就被定住了,不能再動(dòng)了。但任務(wù)還在,只是不動(dòng)了。直到法術(shù)解除。那么這里所謂的現(xiàn)場(chǎng),就是該任務(wù)的TCB任務(wù)控制數(shù)據(jù)結(jié)構(gòu),將暫停時(shí)刻的物理CPU相關(guān)寄存器保存了。

Ready: 就緒態(tài),就是指任務(wù)可以被調(diào)度器裝載進(jìn)CPU核運(yùn)行的狀態(tài),但是還沒有被裝載進(jìn)CPU核。為什么有這樣一個(gè)就緒態(tài)呢?前面說了,RTOS主要作用就是多任務(wù)的調(diào)度管理。那么就緒的任務(wù)就有可能是多個(gè),也就是說在同一時(shí)刻,多個(gè)任務(wù)有可能都就緒了,至于調(diào)度器究竟讓哪一個(gè)任務(wù)先運(yùn)行呢,這就是調(diào)度器調(diào)度算法的職責(zé)了,根據(jù)其內(nèi)部的調(diào)度算法策略進(jìn)行調(diào)度管理。

FreeRTOS支持的調(diào)度算法有:

時(shí)間片調(diào)度策略:也稱為Round Robin調(diào)度算法,Round Robin調(diào)度算法不保證同等優(yōu)先級(jí)的任務(wù)之間平均分配時(shí)間,只保證同等優(yōu)先級(jí)的Ready狀態(tài)任務(wù)會(huì)依次進(jìn)入Running狀態(tài)。

這可能讓人費(fèi)解,首先時(shí)間片Time Slice是指兩個(gè)Tick中斷間的時(shí)間間隔,每次新的Tick中斷時(shí),調(diào)度器會(huì)檢查任務(wù)隊(duì)列中是否有與正在運(yùn)行的任務(wù)優(yōu)先級(jí)相同的就緒態(tài)任務(wù),如果有,就將正在運(yùn)行的任務(wù)換出CPU,將新任務(wù)換入CPU。所以該機(jī)制并不保證相同優(yōu)先級(jí)就緒態(tài)任務(wù)獲得的CPU時(shí)間片相等。

固定優(yōu)先級(jí)搶占式調(diào)度:這種調(diào)度算法根據(jù)任務(wù)的優(yōu)先級(jí)選擇任務(wù)進(jìn)行裝載。換句話說,高優(yōu)先級(jí)任務(wù)總是在低優(yōu)先級(jí)任務(wù)之前獲得CPU。只有當(dāng)沒有處于就緒狀態(tài)的高優(yōu)先級(jí)任務(wù)時(shí),低優(yōu)先級(jí)任務(wù)才能執(zhí)行。

更準(zhǔn)確地理解:如果優(yōu)先級(jí)高于運(yùn)行狀態(tài)任務(wù)的任務(wù)進(jìn)入就緒狀態(tài),搶占式調(diào)度算法將立即“搶占”運(yùn)行狀態(tài)的低優(yōu)先級(jí)任務(wù)。被搶占意味著低優(yōu)先級(jí)任務(wù)馬上被調(diào)度器換出運(yùn)行狀態(tài),并進(jìn)入就緒狀態(tài),而高優(yōu)先級(jí)任務(wù)被轉(zhuǎn)載進(jìn)CPU進(jìn)行運(yùn)行。需要注意的是,低優(yōu)先級(jí)任務(wù)是進(jìn)入就緒態(tài)而非掛起態(tài),當(dāng)高優(yōu)先級(jí)任務(wù)完成運(yùn)行,進(jìn)入阻塞態(tài)后,原低優(yōu)先級(jí)任務(wù)將有機(jī)會(huì)被調(diào)度運(yùn)行。

Blocked: 阻塞態(tài)。所謂阻塞態(tài),可以簡(jiǎn)單理解是任務(wù)被卡在了哪里,該任務(wù)不會(huì)繼續(xù)往下運(yùn)行,直到阻塞解除,被轉(zhuǎn)入就緒態(tài),然后被調(diào)度至運(yùn)行態(tài)。需要注意區(qū)分的是:阻塞態(tài)與暫停態(tài)是兩回事,暫停是被移除調(diào)度列表,除非被人為恢復(fù)進(jìn)任務(wù)調(diào)度表。而阻塞態(tài),當(dāng)阻塞事件解除,會(huì)自動(dòng)進(jìn)入就緒態(tài),從而有機(jī)會(huì)被調(diào)度器換入CPU進(jìn)而運(yùn)行。

阻塞事件基本可以分成兩類:

時(shí)間事件:比如vTaskDelay調(diào)用,任務(wù)將延遲一定的時(shí)間,一旦該函數(shù)被調(diào)用,該任務(wù)就被阻塞,直到延遲的時(shí)間結(jié)束會(huì)進(jìn)入就緒態(tài)。

同步事件:比如等待消息隊(duì)列、獲取信號(hào)量、獲取互斥體等等。

上面說到搶占式調(diào)度算法,看下面這個(gè)圖就比較好理解了,在圖中所示的時(shí)間點(diǎn),高優(yōu)先級(jí)的任務(wù)一旦就緒則會(huì)馬上搶占低優(yōu)先級(jí)任務(wù)。

41f4c2dc-81c2-11ee-939d-92fbcf53809c.png

狀態(tài)切換

前面將狀態(tài)概念擼了一遍,狀態(tài)機(jī)的理解需要從兩個(gè)維度進(jìn)行理解:1.有哪些狀態(tài),每個(gè)狀態(tài)啥物理含義;2.狀態(tài)的切換條件,什么條件會(huì)觸發(fā)狀態(tài)變化。

上面的任務(wù)狀態(tài)圖描述的比較清楚,這里總結(jié)一下這些狀態(tài)究竟怎么切換的:

進(jìn)入掛起態(tài):在任務(wù)的任意狀態(tài)下,一旦應(yīng)用程序調(diào)用了vTaskSuspend這個(gè)API,就會(huì)將指定的任務(wù)設(shè)置掛起態(tài)。

voidvTaskSuspend(TaskHandle_tpxTaskToSuspend);
voidvTaskSuspendAll(void);

以上兩個(gè)任務(wù)都可以用于將任務(wù)設(shè)置成掛起態(tài),vTaskSuspend用于將指定的任務(wù)設(shè)置為掛起態(tài),pxTaskToSuspend就是指定的任務(wù)描述符,而vTaskSuspendAll將所有任務(wù)設(shè)置成掛起態(tài)。

退出掛起態(tài):當(dāng)任務(wù)已經(jīng)處于掛起態(tài),如應(yīng)用需要將其恢復(fù),需要調(diào)用vTaskResume或者xTaskResumeAll,將某個(gè)任務(wù)或者全部任務(wù)恢復(fù)為就緒態(tài)。注意是就緒態(tài)而非運(yùn)行態(tài),進(jìn)入運(yùn)行態(tài)是調(diào)度器實(shí)現(xiàn)的。

voidvTaskResume(TaskHandle_tpxTaskToResume);
BaseType_txTaskResumeAll(void);

要讓任務(wù)恢復(fù)運(yùn)行,上面兩個(gè)API必須要在非掛起態(tài)任務(wù)中調(diào)用,否則是不可能被恢復(fù)的,因?yàn)樘幱趻炱饝B(tài)的任務(wù)是沒有機(jī)會(huì)獲得CPU使用權(quán)運(yùn)行的。

對(duì)于掛起態(tài)的應(yīng)用場(chǎng)景的思考,比如應(yīng)用程序中檢測(cè)到某個(gè)故障了,此時(shí)需要處理故障,就可以將某個(gè)任務(wù)掛起,或者全部掛起,直到故障消除。

進(jìn)入阻塞態(tài):阻塞的概念是相對(duì)于運(yùn)行而言的,也就是說一個(gè)正在運(yùn)行的任務(wù)由于OS API調(diào)用會(huì)卡住不往下運(yùn)行,所以狀態(tài)圖中是運(yùn)行態(tài)會(huì)被阻塞,也就是說該任務(wù)本來正在運(yùn)行,但在這個(gè)調(diào)用之后就會(huì)被調(diào)度器換出CPU。

有哪些API會(huì)讓一個(gè)正處于運(yùn)行的任務(wù)阻塞呢?

1.時(shí)間事件API:

voidvTaskDelay(TickType_txTicksToDelay);
voidvTaskDelayUntil(TickType_t*pxPreviousWakeTime,TickType_txTimeIncrement);

這兩個(gè)API是當(dāng)任務(wù)希望主動(dòng)出讓CPU時(shí)使用,一旦調(diào)用該任務(wù)就被設(shè)置為阻塞態(tài),直到需要等待的時(shí)間結(jié)束,調(diào)度器將相應(yīng)的任務(wù)設(shè)置為就緒態(tài)。調(diào)度器再根據(jù)調(diào)度算法決定是否被裝載進(jìn)CPU核運(yùn)行。

應(yīng)用例子:比如某個(gè)需要固定周期執(zhí)行的任務(wù),就可以在任務(wù)應(yīng)用代碼執(zhí)行完后調(diào)用這個(gè)延遲函數(shù),出讓CPU。讓其他的任務(wù)有機(jī)會(huì)被轉(zhuǎn)載運(yùn)行。

vTaskDelayUntil一般會(huì)先獲取當(dāng)前Tick數(shù),然后再延遲到某一個(gè)增加量。

2.同步事件API:

uint32_tulTaskNotifyTake(BaseType_txClearCountOnExit,TickType_txTicksToWait);
BaseType_txTaskNotifyWait(uint32_tulBitsToClearOnEntry,
uint32_tulBitsToClearOnExit,
uint32_t*pulNotificationValue,
TickType_txTicksToWait);

//消息隊(duì)列相關(guān)
BaseType_txQueueReceive(QueueHandle_txQueue,
void*pvBuffer,
TickType_txTicksToWait);
BaseType_txQueueReceiveFromISR(QueueHandle_txQueue,
void*pvBuffer,
BaseType_t*pxHigherPriorityTaskWoken);
BaseType_txQueuePeek(QueueHandle_txQueue,
void*pvBuffer,TickType_t
xTicksToWait);
BaseType_txQueuePeekFromISR(QueueHandle_txQueue,void*pvBuffer);

//信號(hào)量相關(guān)
BaseType_txSemaphoreTake(SemaphoreHandle_txSemaphore,TickType_txTicksToWait);
BaseType_txSemaphoreTakeFromISR(SemaphoreHandle_txSemaphore,
signedBaseType_t*pxHigherPriorityTaskWoken);
BaseType_txSemaphoreTakeRecursive(SemaphoreHandle_txMutex,
TickType_txTicksToWait);

//stream相關(guān)
size_txStreamBufferReceive(StreamBufferHandle_txStreamBuffer,
void*pvRxData,
size_txBufferLengthBytes,
TickType_txTicksToWait);
size_txStreamBufferReceiveFromISR(StreamBufferHandle_txStreamBuffer,
void*pvRxData,
size_txBufferLengthBytes,
BaseType_t*pxHigherPriorityTaskWoken);
//Event相關(guān)
EventBits_txEventGroupWaitBits(constEventGroupHandle_txEventGroup,
constEventBits_tuxBitsToWaitFor,
constBaseType_txClearOnExit,
constBaseType_txWaitForAllBits,
TickType_txTicksToWait);
EventBits_txEventGroupSync(EventGroupHandle_txEventGroup,
constEventBits_tuxBitsToSet,
constEventBits_tuxBitsToWaitFor,
TickType_txTicksToWait);

//message相關(guān)
size_txMessageBufferReceive(MessageBufferHandle_txMessageBuffer,
void*pvRxData,
size_txBufferLengthBytes,
TickType_txTicksToWait);
size_txMessageBufferReceiveFromISR(MessageBufferHandle_txMessageBuffer,
void*pvRxData,
size_txBufferLengthBytes,
BaseType_t*pxHigherPriorityTaskWoken);

此類任務(wù)主要用于任務(wù)間,或者任務(wù)與中斷間同步或通訊的目的,在等待某一個(gè)消息或者事件的時(shí)候,將該任務(wù)阻塞而不是裸奔的查詢等待,本質(zhì)上就是為了提高CPU的利用率的。

需要注意的是,有的API是不能用于等待來自中斷的消息或者事件的,如果需要與中斷程序同步或者通信,需要使用相應(yīng)的中斷版本API。

總結(jié)一下

將FreeRTOS任務(wù)相關(guān)的狀態(tài)梳理一下,其他的RTOS其實(shí)也是類似的,只不過實(shí)現(xiàn)細(xì)節(jié)會(huì)略有差異,從概念上大體上是相通的。要正確的使用RTOS,清楚正確的理解其任務(wù)狀態(tài)相關(guān)概念是必要的。相關(guān)的API并不需要記憶,只需要理解概念就可以了,用的時(shí)候查一查就好了。

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

    關(guān)注

    6026

    文章

    44460

    瀏覽量

    631214
  • 內(nèi)核
    +關(guān)注

    關(guān)注

    3

    文章

    1351

    瀏覽量

    40160
  • FreeRTOS
    +關(guān)注

    關(guān)注

    12

    文章

    483

    瀏覽量

    61865
  • 狀態(tài)機(jī)
    +關(guān)注

    關(guān)注

    2

    文章

    490

    瀏覽量

    27439

原文標(biāo)題:使用FreeRTOS要好好理解任務(wù)狀態(tài)機(jī)

文章出處:【微信號(hào):玩轉(zhuǎn)嵌入式,微信公眾號(hào):玩轉(zhuǎn)嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Verilog狀態(tài)機(jī)+設(shè)計(jì)實(shí)例

    在verilog中狀態(tài)機(jī)的一種很常用的邏輯結(jié)構(gòu),學(xué)習(xí)和理解狀態(tài)機(jī)的運(yùn)行規(guī)律能夠幫助我們更好地書寫代碼,同時(shí)作為一種思想方法,在別的代碼設(shè)計(jì)中也會(huì)有所幫助。 一、簡(jiǎn)介 在使用過程中我們常說
    的頭像 發(fā)表于 02-12 19:07 ?3494次閱讀
    Verilog<b class='flag-5'>狀態(tài)機(jī)</b>+設(shè)計(jì)實(shí)例

    raw os 之狀態(tài)機(jī)編程

    hsm 狀態(tài)機(jī)概念讀者自行參考有關(guān)概念學(xué)習(xí),這里不再表述。推薦看Practical UML Statecharts in c/c++這本書。raw os的狀態(tài)機(jī)理念,很大部分參考了它
    發(fā)表于 02-27 14:35

    如何寫好狀態(tài)機(jī)

    如何寫好狀態(tài)機(jī):狀態(tài)機(jī)是邏輯設(shè)計(jì)的重要內(nèi)容,狀態(tài)機(jī)的設(shè)計(jì)水平直接反應(yīng)工程師的邏輯功底,所以許多公司的硬件和邏輯工程師面試中,狀態(tài)機(jī)設(shè)計(jì)幾乎是必選題目。本章在引入
    發(fā)表于 06-14 19:24 ?97次下載

    狀態(tài)機(jī)思路在單片機(jī)程序設(shè)計(jì)中的應(yīng)用

    狀態(tài)機(jī)思路在單片機(jī)程序設(shè)計(jì)中的應(yīng)用 狀態(tài)機(jī)概念       狀態(tài)機(jī)是軟件編程中的一個(gè)
    發(fā)表于 03-18 15:00 ?1232次閱讀
    <b class='flag-5'>狀態(tài)機(jī)</b>思路在單片<b class='flag-5'>機(jī)</b>程序設(shè)計(jì)中的應(yīng)用

    狀態(tài)機(jī)舉例

    狀態(tài)機(jī)舉例 你可以指定狀態(tài)寄存器和狀態(tài)機(jī)狀態(tài)。以下是一個(gè)有四種狀態(tài)的普通狀態(tài)機(jī)。 // Th
    發(fā)表于 03-28 15:18 ?956次閱讀

    兩段式狀態(tài)機(jī)不可能完成的任務(wù)

    最近折騰 狀態(tài)機(jī) ,發(fā)現(xiàn)一個(gè)小任務(wù)對(duì)于兩段式狀態(tài)機(jī)寫法是不可能完成的。這個(gè)小任務(wù)很簡(jiǎn)單,先看用一段式狀態(tài)機(jī)實(shí)現(xiàn)的代碼: module tes
    發(fā)表于 05-16 15:44 ?7876次閱讀
    兩段式<b class='flag-5'>狀態(tài)機(jī)</b>不可能完成的<b class='flag-5'>任務(wù)</b>

    狀態(tài)機(jī)代碼生成工具

    狀態(tài)機(jī)代碼生成工具狀態(tài)機(jī)代碼生成工具狀態(tài)機(jī)代碼生成工具狀態(tài)機(jī)代碼生成工具
    發(fā)表于 11-19 15:12 ?9次下載

    狀態(tài)機(jī)原理及用法

    狀態(tài)機(jī)原理及用法狀態(tài)機(jī)原理及用法狀態(tài)機(jī)原理及用法
    發(fā)表于 03-15 15:25 ?0次下載

    狀態(tài)機(jī)原理進(jìn)行軟件設(shè)計(jì)

    組成部分。 不過,狀態(tài)機(jī)理論的發(fā)展卻很緩慢。在眾多原因中,狀態(tài)機(jī)只是做為編程的實(shí)現(xiàn)工具而不是設(shè)計(jì)工具是一個(gè)最重要的原因。 本文的重點(diǎn)就在于,怎樣利用狀態(tài)機(jī)原理進(jìn)行程序設(shè)計(jì)。本文會(huì)先給出普通的、一個(gè)平面上的FSM(有限
    發(fā)表于 12-02 15:03 ?517次閱讀

    狀態(tài)機(jī)概述 如何理解狀態(tài)機(jī)

    本篇文章包括狀態(tài)機(jī)的基本概述以及通過簡(jiǎn)單的實(shí)例理解狀態(tài)機(jī)
    的頭像 發(fā)表于 01-02 18:03 ?1w次閱讀
    <b class='flag-5'>狀態(tài)機(jī)</b>概述  如何理解<b class='flag-5'>狀態(tài)機(jī)</b>

    FPGA:狀態(tài)機(jī)簡(jiǎn)述

    本文目錄 前言 狀態(tài)機(jī)簡(jiǎn)介 狀態(tài)機(jī)分類 Mealy 型狀態(tài)機(jī) Moore 型狀態(tài)機(jī) 狀態(tài)機(jī)描述 一段式
    的頭像 發(fā)表于 11-05 17:58 ?7211次閱讀
    FPGA:<b class='flag-5'>狀態(tài)機(jī)</b>簡(jiǎn)述

    基于狀態(tài)相關(guān)字段的二進(jìn)制私有協(xié)議狀態(tài)機(jī)推斷

    基于狀態(tài)相關(guān)字段的二進(jìn)制私有協(xié)議狀態(tài)機(jī)推斷
    發(fā)表于 06-27 15:30 ?6次下載

    什么是狀態(tài)機(jī)?狀態(tài)機(jī)5要素

    玩單片機(jī)還可以,各個(gè)外設(shè)也都會(huì)驅(qū)動(dòng),但是如果讓你完整的寫一套代碼時(shí),卻無(wú)邏輯與框架可言。這說明編程還處于比較低的水平,你需要學(xué)會(huì)一種好的編程框架或者一種編程思想!比如模塊化編程、狀態(tài)機(jī)編程、分層思想
    的頭像 發(fā)表于 07-27 11:23 ?2w次閱讀
    什么是<b class='flag-5'>狀態(tài)機(jī)</b>?<b class='flag-5'>狀態(tài)機(jī)</b>5要素

    狀態(tài)模式(狀態(tài)機(jī))

    以前寫狀態(tài)機(jī),比較常用的方式是用 if-else 或 switch-case,高級(jí)的一點(diǎn)是函數(shù)指針列表。最近,看了一文章《c語(yǔ)言設(shè)計(jì)模式–狀態(tài)模式(狀態(tài)機(jī))》(來源:embed linux
    發(fā)表于 12-16 16:53 ?8次下載
    <b class='flag-5'>狀態(tài)</b>模式(<b class='flag-5'>狀態(tài)機(jī)</b>)

    什么是狀態(tài)機(jī)?狀態(tài)機(jī)的種類與實(shí)現(xiàn)

    狀態(tài)機(jī),又稱有限狀態(tài)機(jī)(Finite State Machine,F(xiàn)SM)或米利狀態(tài)機(jī)(Mealy Machine),是一種描述系統(tǒng)狀態(tài)變化的模型。在芯片設(shè)計(jì)中,
    的頭像 發(fā)表于 10-19 10:27 ?8634次閱讀