在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

基于事件驅(qū)動(dòng)的有限狀態(tài)機(jī)介紹

Q4MP_gh_c472c21 ? 來源:Gitee ? 作者:Gitee ? 2021-11-16 15:29 ? 次閱讀

一、介紹

EFSM(event finite state machine,事件驅(qū)動(dòng)型有限狀態(tài)機(jī)),是一個(gè)基于事件驅(qū)動(dòng)的有限狀態(tài)機(jī),主要應(yīng)用于嵌入式設(shè)備的軟件系統(tǒng)中。

EFSM的設(shè)計(jì)原則是:簡單!EFSM的使用者只需要關(guān)心:

  1. 當(dāng)事件到來時(shí),通過EFSM取得對(duì)應(yīng)事件的處理方法
  2. 當(dāng)特定事件到來,或者條件滿足時(shí),調(diào)用狀態(tài)切換方法進(jìn)行狀態(tài)切換

由于EFSM的巧妙設(shè)計(jì),避免了命名沖突的問題,你可以在一個(gè)程序中定義多個(gè)狀態(tài)機(jī);要是能對(duì)不同狀態(tài)進(jìn)行組織,還可以做出層次狀態(tài)機(jī)的結(jié)構(gòu)。

EFSM總共分為兩個(gè)部分:

  • EFSM核心:由uthash.h、efsm.h和efsm_conf.h三個(gè)文件組成;他們構(gòu)成了事件驅(qū)動(dòng)型狀態(tài)機(jī)的核心;使用的時(shí)候只需要包含efsm.h即可;
  • EFSM擴(kuò)展:在EFSM核心的基礎(chǔ)上,增加efsmt.h和efsmt.c兩個(gè)文件,這兩個(gè)文件會(huì)根據(jù)具體的狀態(tài)機(jī)創(chuàng)建狀態(tài)機(jī)線程,用于驅(qū)動(dòng)狀態(tài)機(jī)運(yùn)轉(zhuǎn);使用的時(shí)候只需要包含efsmt.h即可;

二、接口總覽

EFSM總共提供了兩套接口,你只需要選擇其中套用法即可。全部接口概述如下:

2.1 使用狀態(tài)機(jī)工具集(EFSM核心)

若你想自己把控狀態(tài)機(jī)的整個(gè)運(yùn)轉(zhuǎn)過程,可以直接使用EFSM核心,詳細(xì)接口如下。

1. 狀態(tài)操作接口

API 說明 參數(shù)
EFSM_SETS 用于創(chuàng)建某一狀態(tài)下不同時(shí)間的處理集合 類型,無參數(shù)
EFSM_CREATE(state) 用于創(chuàng)建某一狀態(tài)名 state是狀態(tài)名
EFSM_DECLEAR(state) 當(dāng)在其它地方需要使用到某個(gè)狀態(tài)時(shí),用于聲明 state是狀態(tài)名
EFSM_BIND(state, sets) 用于將狀態(tài)state與處理集sets進(jìn)行綁定 state是狀態(tài)名,sets是處理集

2. 狀態(tài)指針操作接口

API 說明 參數(shù)
EFSM_PTR_CREATE(name) 用于創(chuàng)建一個(gè)狀態(tài)機(jī)指針 name是狀態(tài)機(jī)指針名
EFSM_PTR_DECLEAR(name) 當(dāng)在其它地方需要使用到某個(gè)狀態(tài)指針時(shí),用于聲明 name是狀態(tài)機(jī)指針名
EFSM_PTR_BIND(name, state) 用于為狀態(tài)機(jī)指針name綁定到初始狀態(tài)state,只調(diào)用一次 name是狀態(tài)機(jī)指針名,state是狀態(tài)名

3. 狀態(tài)切換接口

API 說明 參數(shù)
EFSM_TRANSFER(name, state) 用于把狀態(tài)機(jī)name切換到state狀態(tài) name是狀態(tài)機(jī)指針名,state是狀態(tài)名
EFSM_TRANSFER_ENABLE(name) 使能狀態(tài)切換功能,在EFSM_TRANSFER()前調(diào)用 name是狀態(tài)機(jī)指針名
EFSM_TRANSFER_DISABLE(name) 除能狀態(tài)切換功能,在EFSM_TRANSFER()后調(diào)用 name是狀態(tài)機(jī)指針名

4. 獲取處理函數(shù)接口

API 說明 參數(shù)
EFSM_HANDLER(name, event) 用與當(dāng)某個(gè)事件到來時(shí),通過該方法獲取到當(dāng)前狀態(tài)下的對(duì)應(yīng)處理方法 name是狀態(tài)機(jī)指針名,event是事件

2.2 使用狀態(tài)機(jī)

若你不關(guān)心狀態(tài)機(jī)的內(nèi)部細(xì)節(jié)實(shí)現(xiàn),需要一個(gè)可直接運(yùn)轉(zhuǎn)的狀態(tài)機(jī),那么請(qǐng)使用efsmt.h頭文件,并將efsmt.c編譯進(jìn)你的源碼。詳細(xì)接口如下。

1. 狀態(tài)操作接口

API 說明 參數(shù)
EFSM_SETS 用于創(chuàng)建某一狀態(tài)下不同時(shí)間的處理集合 類型,無參數(shù)
EFSM_CREATE(state) 用于創(chuàng)建某一狀態(tài)名 state是狀態(tài)名
EFSM_DECLEAR(state) 當(dāng)在其它地方需要使用到某個(gè)狀態(tài)時(shí),用于聲明 state是狀態(tài)名
EFSM_BIND(state, sets) 用于將狀態(tài)state與處理集sets進(jìn)行綁定 state是狀態(tài)名,sets是處理集

2. 狀態(tài)機(jī)操作接口

API 說明 參數(shù)
EFSMT_CREATE(name) 創(chuàng)建一個(gè)狀態(tài)機(jī) name是狀態(tài)機(jī)名
EFSMT_DESTROY(name) 當(dāng)不再使用狀態(tài)機(jī)時(shí),用于銷毀 name是狀態(tài)機(jī)名
EFSMT_DECLEAR(name) 當(dāng)在其它地方需要使用到狀態(tài)機(jī)時(shí),用于聲明 name是狀態(tài)機(jī)名
EFSMT_BIND(name, state) 用于綁定狀態(tài)機(jī)的初始狀態(tài) name是狀態(tài)機(jī)名,state是狀態(tài)名

3. 狀態(tài)切換接口

API 說明 參數(shù)
EFSM_TRANSFER(name, state) 用于把狀態(tài)機(jī)name切換到state狀態(tài) name是狀態(tài)機(jī)指針名,state是狀態(tài)名
EFSM_TRANSFER_ENABLE(name) 使能狀態(tài)切換功能,在EFSM_TRANSFER()前調(diào)用 name是狀態(tài)機(jī)指針名
EFSM_TRANSFER_DISABLE(name) 除能狀態(tài)切換功能,在EFSM_TRANSFER()后調(diào)用 name是狀態(tài)機(jī)指針名

4. 觸發(fā)事件接口

API 說明 參數(shù)
EFSMT_INVOKE(name, event, arg) 當(dāng)事件到來時(shí),觸發(fā)該事件,狀態(tài)機(jī)會(huì)自動(dòng)尋找并調(diào)用對(duì)應(yīng)的處理事件 name是狀態(tài)機(jī)名,event是事件,arg是事件參數(shù)

2.3 總結(jié)

從接口可以看出,創(chuàng)建處理集與狀態(tài)集,和狀態(tài)切換方法是完全一樣的;兩種方法的唯一差異就是:當(dāng)事件來了之后,事件對(duì)應(yīng)的處理是由你來控制,還是由狀態(tài)機(jī)內(nèi)部進(jìn)行控制。

三、使用說明

要使用EFSM,非常簡單,只需要如下三步:定義事件集、定義狀態(tài)集、使用狀態(tài)集。

3.1 定義事件集

在我們?cè)O(shè)計(jì)業(yè)務(wù)/功能時(shí),首先對(duì)需要使用到的事件進(jìn)行定義。具體實(shí)現(xiàn)方法是在efsm_event.h文件中,使用EFSM_EVENT()宏定義需要的事件。如果你需要定義多個(gè)狀態(tài)機(jī),那請(qǐng)將不同狀態(tài)機(jī)的事件分塊保存,建議使用enum進(jìn)行管理。比如:

enum{
EVENT_PLAY=EFSM_EVENT(1),
EVENT_STOP=EFSM_EVENT(2),
EVENT_NEXT=EFSM_EVENT(3),
EVENT_PREV=EFSM_EVENT(4),
EVENT_START=EFSM_EVENT(7),//notrequirecontinuous
};

3.2 定義狀態(tài)集

  1. 定義狀態(tài):使用EFSM_CREATE(state)創(chuàng)建一個(gè)狀態(tài)state;在其它使用到它的地方用EFSM_DECLEAR(state)宏進(jìn)行聲明;
  2. 定義處理集:使用EFSM_SETS state_sets定義一個(gè)狀態(tài)集合state_sets,其中每個(gè)事件可以對(duì)應(yīng)一個(gè)處理函數(shù),也可以對(duì)應(yīng)多個(gè)函數(shù),當(dāng)然也可以為NULL;處理函數(shù)需滿足如下格式:
typedefvoid(*EFSM_EVENT_HANDLER)(EFSM_EVENT_TYPEevent,void*arg);
  1. 綁定狀態(tài)與處理集:在模塊初始化函數(shù)中調(diào)用EFSM_BIND(state, sets)宏將狀態(tài)state與處理集sets進(jìn)行綁定;

3.3 使用狀態(tài)集

當(dāng)為模塊/產(chǎn)品實(shí)現(xiàn)了所有的狀態(tài),那么編寫業(yè)務(wù)應(yīng)用程序來實(shí)現(xiàn)調(diào)度,讓所有的狀態(tài)機(jī)完美的運(yùn)作起來。具體使用方法如下:

  1. 定義狀態(tài)指針:使用EFSM_PTR_CREATE(name)定義一個(gè)狀態(tài)指針name;當(dāng)然你也可以定義多個(gè)狀態(tài)指針,每個(gè)指針對(duì)應(yīng)一個(gè)狀態(tài)機(jī)。在其它使用到該狀態(tài)指針的地方使用EFSM_PTR_DECLEAR(name)宏進(jìn)行聲明;
  2. 綁定初始狀態(tài):在整個(gè)狀態(tài)機(jī)運(yùn)作之前,需要使用EFSM_PTR_BIND(name, state)宏將狀態(tài)指針name與狀態(tài)state進(jìn)行綁定;
  3. 獲取處理函數(shù)指針:當(dāng)接收到某個(gè)事件時(shí),可以通過EFSM_HANDLER(name,event)宏從狀態(tài)指針name中獲取對(duì)該事件的處理方法,第一個(gè)參數(shù)是狀態(tài)指針,第二個(gè)參數(shù)為事件;
  4. 狀態(tài)切換:當(dāng)遇到某個(gè)事件,或者在事件處理函數(shù)中條件滿足,需要進(jìn)行狀態(tài)切換時(shí),使用下面流程進(jìn)行切換:
EFSM_TRANSFER_ENABLE(name);
EFSM_TRANSFER(name,state);
EFSM_TRANSFER_DISABLE(name);
  • EFSM_TRANSFER_ENABLE(name)宏使能狀態(tài)指針name的切換能力;
  • EFSM_TRANSFER_DISABLE(name)宏除能狀態(tài)指針name的切換能力;
  • EFSM_TRANSFER(name, state)宏執(zhí)行狀態(tài)指針name切換到state;

注意:做狀態(tài)切換時(shí),必須滿足ENABLE()->TRANSFER()->DISABLE()的流程。這么做的目的,是為了讓編程者思考:狀態(tài)設(shè)計(jì)與狀態(tài)的跳轉(zhuǎn)是否必要與合理

四、常見問題

  1. 使用過程中若遇到如下錯(cuò)誤,是因?yàn)樵谡绞褂们埃瑳]有把狀態(tài)指針綁定到具體的狀態(tài):
EFSM:cur-state-ptrhave'tbindastate:%xxx!!!
  1. 使用過程中若遇到如下錯(cuò)誤,是因?yàn)闋顟B(tài)切換動(dòng)作不滿足ENABLE()->TRANSFER()->DISABLE()的流程:
EFSM:'xxx'switchto'xxx'failed!!!
  1. 使用過程中,若遇到了死鎖或卡死,是因?yàn)闋顟B(tài)切換動(dòng)作不滿足ENABLE()->TRANSFER()->DISABLE()的流程:
  2. 命名定義了處理函數(shù),為什么每次EFSM_HANDLER()得到的都是NULL?答:因?yàn)槟銢]有將狀態(tài)與事件集進(jìn)行綁定。
  3. 對(duì)于某個(gè)狀態(tài)沒有使用到的事件,我是否可以不對(duì)其定義?答:完全可以,這樣還可以加快EFSM的處理速度。不過不建議直接刪除,而采用注釋的形式,比如:
EFSM_SETSonline[]={{EVENT_PLAY,online_play},
/*{EVENT_STOP,NULL},*/
{EVENT_NEXT,online_next},
/*{EVENT_PREV,NULL},*/
{EVENT_START,online_start},
};

END 原文地址:https://gitee.com/simpost/EFSM/tree/master/ 責(zé)任編輯:haq

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

    關(guān)注

    5082

    文章

    19126

    瀏覽量

    305197
  • 驅(qū)動(dòng)
    +關(guān)注

    關(guān)注

    12

    文章

    1840

    瀏覽量

    85291

原文標(biāo)題:分享一個(gè)基于事件驅(qū)動(dòng)的有限狀態(tài)機(jī)

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Simulink中的狀態(tài)機(jī)建模方法 Simulink數(shù)據(jù)可視化與分析功能

    1. Simulink中的狀態(tài)機(jī)建模方法 1.1 理解狀態(tài)機(jī)的基本概念 在開始建模之前,了解狀態(tài)機(jī)的基本概念是必要的。狀態(tài)機(jī)由以下幾個(gè)部分組成:
    的頭像 發(fā)表于 12-12 09:27 ?412次閱讀

    觸發(fā)器和狀態(tài)機(jī)的關(guān)系是什么

    觸發(fā)器和狀態(tài)機(jī)在數(shù)字電路設(shè)計(jì)中有著緊密的關(guān)系,它們共同構(gòu)成了時(shí)序邏輯電路的基礎(chǔ),用于實(shí)現(xiàn)數(shù)據(jù)的存儲(chǔ)、處理和傳輸。
    的頭像 發(fā)表于 08-12 11:24 ?459次閱讀

    如何在FPGA中實(shí)現(xiàn)狀態(tài)機(jī)

    在FPGA(現(xiàn)場可編程門陣列)中實(shí)現(xiàn)狀態(tài)機(jī)是一種常見的做法,用于控制復(fù)雜的數(shù)字系統(tǒng)行為。狀態(tài)機(jī)能夠根據(jù)當(dāng)前的輸入和系統(tǒng)狀態(tài),決定下一步的動(dòng)作和新的狀態(tài)。這里,我們將詳細(xì)探討如何在FPG
    的頭像 發(fā)表于 07-18 15:57 ?601次閱讀

    玩轉(zhuǎn)Spring狀態(tài)機(jī)

    說起Spring狀態(tài)機(jī),大家很容易聯(lián)想到這個(gè)狀態(tài)機(jī)和設(shè)計(jì)模式中狀態(tài)模式的區(qū)別是啥呢?沒錯(cuò),Spring狀態(tài)機(jī)就是狀態(tài)模式的一種實(shí)現(xiàn),在
    的頭像 發(fā)表于 06-25 14:21 ?953次閱讀
    玩轉(zhuǎn)Spring<b class='flag-5'>狀態(tài)機(jī)</b>

    關(guān)于SMU狀態(tài)機(jī)的問題求解

    我有一些關(guān)于 SMU 狀態(tài)機(jī)的問題。 假設(shè)由于某種原因,SMU 已進(jìn)入故障狀態(tài)。 手冊(cè)指出,要返回運(yùn)行狀態(tài)并將 FSP 恢復(fù)到無故障狀態(tài),應(yīng)調(diào)用IfxSmu_releaseFSP()。
    發(fā)表于 05-29 08:18

    使用系統(tǒng)滴答定時(shí)中斷,基于按鍵的狀態(tài)機(jī)怎么只能1個(gè)1個(gè)+,不能連+?

    使用系統(tǒng)滴答定時(shí)中斷,基于按鍵的狀態(tài)機(jī)怎么只能1個(gè)1個(gè)+,不能連+ #define KEY1_USERGPIO_ReadInputDataBit(GPIOC,GPIO_Pin_13
    發(fā)表于 05-16 06:27

    請(qǐng)問STM32F051用了操作系統(tǒng)RTX后還需要寫狀態(tài)機(jī)不?

    現(xiàn)在學(xué)會(huì)了rtx操作系統(tǒng)后,原來用狀態(tài)機(jī)的學(xué)的程序,可不可以不切割,直接單線程來執(zhí)行列?各位前前輩指點(diǎn)一下。多謝!
    發(fā)表于 05-08 06:11

    在Verilog中實(shí)現(xiàn)Moore型和Mealy型狀態(tài)機(jī)的方法簡析

    編寫能夠被綜合工具識(shí)別的狀態(tài)機(jī),首先需要理解狀態(tài)機(jī)的基本概念和分類。狀態(tài)機(jī)(FSM)是表示有限個(gè)狀態(tài)以及在這些
    的頭像 發(fā)表于 05-01 11:38 ?1615次閱讀

    嵌入式編程,如何用 C 語言實(shí)現(xiàn)狀態(tài)機(jī)設(shè)計(jì)?

    狀態(tài)機(jī)模式是一種行為模式,通過多態(tài)實(shí)現(xiàn)不同狀態(tài)的調(diào)轉(zhuǎn)行為的確是一種很好的方法,只可惜在嵌入式環(huán)境下,有時(shí)只能寫純C代碼,并且還需要考慮代碼的重入和多任務(wù)請(qǐng)求跳轉(zhuǎn)等情形,因此實(shí)現(xiàn)起來著實(shí)需要一番考慮
    發(fā)表于 04-23 11:00

    求助LabVIEW,狀態(tài)機(jī)里面反饋節(jié)點(diǎn)如何初始化問題

    求助labview,狀態(tài)機(jī)里面反饋節(jié)點(diǎn)如何初始化,下次執(zhí)行這個(gè)狀態(tài)的時(shí)候初始化一次!謝謝謝謝!
    發(fā)表于 03-25 18:17

    如何采用“狀態(tài)機(jī)”解析UART數(shù)據(jù)幀

    如果一個(gè)系統(tǒng)接收上述“不定長度”的協(xié)議幀,將會(huì)有一個(gè)挑戰(zhàn)--如何高效接收與解析。 為簡化系統(tǒng)設(shè)計(jì),我們強(qiáng)烈建議您采用“狀態(tài)機(jī)”來解析UART數(shù)據(jù)幀。
    的頭像 發(fā)表于 03-25 14:29 ?698次閱讀
    如何采用“<b class='flag-5'>狀態(tài)機(jī)</b>”解析UART數(shù)據(jù)幀

    請(qǐng)問GPIF狀態(tài)機(jī)的內(nèi)部信號(hào)需要延遲才能斷言嗎?

    dma_wm_thn 這樣的過渡觸發(fā)器需要一些周期的延遲才能斷言嗎? 在我的實(shí)踐中,DMA_WM_THN 觸發(fā)器似乎有 1 個(gè)時(shí)鐘周期延遲: ? 圖像是我的狀態(tài)機(jī)的一部分,數(shù)據(jù)總線是 32 位
    發(fā)表于 02-23 07:43

    什么是有限狀態(tài)機(jī)?如何解決傳統(tǒng)有限狀態(tài)機(jī)狀態(tài)爆炸」問題?

    有限狀態(tài)機(jī)(Finite State Machine,簡稱FSM)是一種用來進(jìn)行對(duì)象行為建模的工具,其作用主要是描述對(duì)象在它的生命周期內(nèi)所經(jīng)歷的狀態(tài)序列以及如何響應(yīng)來自外界的各種事件。
    的頭像 發(fā)表于 02-17 16:09 ?6250次閱讀
    什么是<b class='flag-5'>有限狀態(tài)機(jī)</b>?如何解決傳統(tǒng)<b class='flag-5'>有限狀態(tài)機(jī)</b>「<b class='flag-5'>狀態(tài)</b>爆炸」問題?

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

    的是有限狀態(tài)機(jī)(Finite-State Machine,F(xiàn)SM),簡稱為狀態(tài)機(jī),表示在有限個(gè)狀態(tài)以及這些狀態(tài)之間的轉(zhuǎn)移和動(dòng)作等行為的數(shù)學(xué)模
    的頭像 發(fā)表于 02-12 19:07 ?4142次閱讀
    Verilog<b class='flag-5'>狀態(tài)機(jī)</b>+設(shè)計(jì)實(shí)例

    狀態(tài)機(jī)該怎么監(jiān)控

    狀態(tài)機(jī)卡住的場景——通過狀態(tài)跳轉(zhuǎn)條件的DFX信號(hào)去判斷卡住的原因
    的頭像 發(fā)表于 01-15 10:03 ?420次閱讀
    <b class='flag-5'>狀態(tài)機(jī)</b>該怎么監(jiān)控
    主站蜘蛛池模板: 人人草人| 欧美专区欧美吧| h在线国产| 天天寡妇色| 国产精品亚洲四区在线观看 | 久久老色鬼天天综合网观看| 日本一区二区三区四区视频 | 亚洲a网站| 人操人摸| 天堂网www中文在线| 日本免费一区二区在线观看| 欧美精品二区| 欧美aaaaa性bbbbb小妇| 不卡视频一区| 国产日韩一区二区三区| 51xx嘿嘿午夜| 色女人久久| 天天色天天操天天| 国卡一卡二卡三免费网站| 精品伊人久久大香线蕉网站| 就操| 亚洲天天做日日做天天看2018| 国产高清一区二区三区| 奇米777me| 欧美婷婷色| 久久天天综合| 婷婷丁香亚洲| 亚洲视频精选| 狠狠成人| www.五月婷婷.com| 深夜动态福利gif动态进| 久久不射影院| 欧美黑人性受xxxx精品| 欧美资源在线| 国产午夜在线视频| 色天使美国| 欧美性色生活片天天看99| 亚色图| 天天干天天草| 亚洲网色| 天天插天天色|