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

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于事件驅動的有限狀態機介紹

lilihe92 ? 來源:最后一個bug ? 2023-02-11 10:17 ? 次閱讀

一、介紹

EFSM(event finite state machine,事件驅動型有限狀態機),是一個基于事件驅動的有限狀態機,主要應用于嵌入式設備的軟件系統中。

EFSM的設計原則是:簡單!EFSM的使用者只需要關心:

當事件到來時,通過EFSM取得對應事件的處理方法

當特定事件到來,或者條件滿足時,調用狀態切換方法進行狀態切換

由于EFSM的巧妙設計,避免了命名沖突的問題,你可以在一個程序中定義多個狀態機;要是能對不同狀態進行組織,還可以做出層次狀態機的結構。

EFSM總共分為兩個部分:

EFSM核心:由uthash.h、efsm.h和efsm_conf.h三個文件組成;他們構成了事件驅動型狀態機的核心;使用的時候只需要包含efsm.h即可;

EFSM擴展:在EFSM核心的基礎上,增加efsmt.h和efsmt.c兩個文件,這兩個文件會根據具體的狀態機創建狀態機線程,用于驅動狀態機運轉;使用的時候只需要包含efsmt.h即可;

二、接口總覽

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

2.1 使用狀態機工具集(EFSM核心)

若你想自己把控狀態機的整個運轉過程,可以直接使用EFSM核心,詳細接口如下。

1. 狀態操作接口

API 說明 參數
EFSM_SETS 用于創建某一狀態下不同時間的處理集合 類型,無參數
EFSM_CREATE(state) 用于創建某一狀態名 state是狀態名
EFSM_DECLEAR(state) 當在其它地方需要使用到某個狀態時,用于聲明 state是狀態名
EFSM_BIND(state, sets) 用于將狀態state與處理集sets進行綁定 state是狀態名,sets是處理集

2. 狀態指針操作接口

API 說明 參數
EFSM_PTR_CREATE(name) 用于創建一個狀態機指針 name是狀態機指針名
EFSM_PTR_DECLEAR(name) 當在其它地方需要使用到某個狀態指針時,用于聲明 name是狀態機指針名
EFSM_PTR_BIND(name, state) 用于為狀態機指針name綁定到初始狀態state,只調用一次 name是狀態機指針名,state是狀態名

3. 狀態切換接口

API 說明 參數
EFSM_TRANSFER(name, state) 用于把狀態機name切換到state狀態 name是狀態機指針名,state是狀態名
EFSM_TRANSFER_ENABLE(name) 使能狀態切換功能,在EFSM_TRANSFER()前調用 name是狀態機指針名
EFSM_TRANSFER_DISABLE(name) 除能狀態切換功能,在EFSM_TRANSFER()后調用 name是狀態機指針名

4. 獲取處理函數接口

API 說明 參數
EFSM_HANDLER(name, event) 用與當某個事件到來時,通過該方法獲取到當前狀態下的對應處理方法 name是狀態機指針名,event是事件

2.2 使用狀態機

若你不關心狀態機的內部細節實現,需要一個可直接運轉的狀態機,那么請使用efsmt.h頭文件,并將efsmt.c編譯進你的源碼。詳細接口如下。

1. 狀態操作接口

API 說明 參數
EFSM_SETS 用于創建某一狀態下不同時間的處理集合 類型,無參數
EFSM_CREATE(state) 用于創建某一狀態名 state是狀態名
EFSM_DECLEAR(state) 當在其它地方需要使用到某個狀態時,用于聲明 state是狀態名
EFSM_BIND(state, sets) 用于將狀態state與處理集sets進行綁定 state是狀態名,sets是處理集

2. 狀態機操作接口

API 說明 參數
EFSMT_CREATE(name) 創建一個狀態機 name是狀態機名
EFSMT_DESTROY(name) 當不再使用狀態機時,用于銷毀 name是狀態機名
EFSMT_DECLEAR(name) 當在其它地方需要使用到狀態機時,用于聲明 name是狀態機名
EFSMT_BIND(name, state) 用于綁定狀態機的初始狀態 name是狀態機名,state是狀態名

3. 狀態切換接口

API 說明 參數
EFSM_TRANSFER(name, state) 用于把狀態機name切換到state狀態 name是狀態機指針名,state是狀態名
EFSM_TRANSFER_ENABLE(name) 使能狀態切換功能,在EFSM_TRANSFER()前調用 name是狀態機指針名
EFSM_TRANSFER_DISABLE(name) 除能狀態切換功能,在EFSM_TRANSFER()后調用 name是狀態機指針名

4. 觸發事件接口

API 說明 參數
EFSMT_INVOKE(name, event, arg) 當事件到來時,觸發該事件,狀態機會自動尋找并調用對應的處理事件 name是狀態機名,event是事件,arg是事件參數

2.3 總結

從接口可以看出,創建處理集與狀態集,和狀態切換方法是完全一樣的;兩種方法的唯一差異就是:當事件來了之后,事件對應的處理是由你來控制,還是由狀態機內部進行控制。

三、使用說明

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

3.1 定義事件集

在我們設計業務/功能時,首先對需要使用到的事件進行定義。具體實現方法是在efsm_event.h文件中,使用EFSM_EVENT()宏定義需要的事件。如果你需要定義多個狀態機,那請將不同狀態機的事件分塊保存,建議使用enum進行管理。比如:

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 定義狀態集

定義狀態:使用EFSM_CREATE(state)創建一個狀態state;在其它使用到它的地方用EFSM_DECLEAR(state)宏進行聲明;

定義處理集:使用EFSM_SETS state_sets定義一個狀態集合state_sets,其中每個事件可以對應一個處理函數,也可以對應多個函數,當然也可以為NULL;處理函數需滿足如下格式:

typedefvoid(*EFSM_EVENT_HANDLER)(EFSM_EVENT_TYPEevent,void*arg);

綁定狀態與處理集:在模塊初始化函數中調用EFSM_BIND(state, sets)宏將狀態state與處理集sets進行綁定;

3.3 使用狀態集

當為模塊/產品實現了所有的狀態,那么編寫業務應用程序來實現調度,讓所有的狀態機完美的運作起來。具體使用方法如下:

定義狀態指針:使用EFSM_PTR_CREATE(name)定義一個狀態指針name;當然你也可以定義多個狀態指針,每個指針對應一個狀態機。在其它使用到該狀態指針的地方使用EFSM_PTR_DECLEAR(name)宏進行聲明;

綁定初始狀態:在整個狀態機運作之前,需要使用EFSM_PTR_BIND(name, state)宏將狀態指針name與狀態state進行綁定;

獲取處理函數指針:當接收到某個事件時,可以通過EFSM_HANDLER(name,event)宏從狀態指針name中獲取對該事件的處理方法,第一個參數是狀態指針,第二個參數為事件;

狀態切換:當遇到某個事件,或者在事件處理函數中條件滿足,需要進行狀態切換時,使用下面流程進行切換:

EFSM_TRANSFER_ENABLE(name);
EFSM_TRANSFER(name,state);
EFSM_TRANSFER_DISABLE(name);

EFSM_TRANSFER_ENABLE(name)宏使能狀態指針name的切換能力;

EFSM_TRANSFER_DISABLE(name)宏除能狀態指針name的切換能力;

EFSM_TRANSFER(name, state)宏執行狀態指針name切換到state;

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

四、常見問題

使用過程中若遇到如下錯誤,是因為在正式使用前,沒有把狀態指針綁定到具體的狀態:

EFSM:cur-state-ptrhave'tbindastate:%xxx!!!

使用過程中若遇到如下錯誤,是因為狀態切換動作不滿足ENABLE()->TRANSFER()->DISABLE()的流程:

EFSM:'xxx'switchto'xxx'failed!!!

使用過程中,若遇到了死鎖或卡死,是因為狀態切換動作不滿足ENABLE()->TRANSFER()->DISABLE()的流程:

命名定義了處理函數,為什么每次EFSM_HANDLER()得到的都是NULL?答:因為你沒有將狀態與事件集進行綁定。

對于某個狀態沒有使用到的事件,我是否可以不對其定義?答:完全可以,這樣還可以加快EFSM的處理速度。不過不建議直接刪除,而采用注釋的形式,比如:

EFSM_SETSonline[]={{EVENT_PLAY,online_play},
/*{EVENT_STOP,NULL},*/
{EVENT_NEXT,online_next},
/*{EVENT_PREV,NULL},*/
{EVENT_START,online_start},
};

審核編輯:陳陳

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

    關注

    2

    文章

    492

    瀏覽量

    27593
  • 事件驅動
    +關注

    關注

    0

    文章

    9

    瀏覽量

    6758

原文標題:分享一個基于事件驅動的有限狀態機

文章出處:【微信號:最后一個bug,微信公眾號:最后一個bug】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    FPGA有限狀態機

    FPGA有限狀態機
    發表于 09-08 08:45

    有限狀態機有什么類型?

    在實際的應用中,根據有限狀態機是否使用輸入信號,設計人員經常將其分為Moore型有限狀態機和Mealy型有限狀態機兩種類型。
    發表于 04-06 09:00

    什么是有限狀態機

    在嵌入式,機器人領域,由于多的復雜邏輯狀態,我們編寫程序的時候不得不考慮很多種情況,容易造成功能間的沖突。有限狀態機(finite-state machine),簡稱狀態機,是一種表示有限
    發表于 12-20 06:51

    有限狀態機_FSM_的實現

    本文主要介紹了IP模塊的有限狀態機的實現。
    發表于 03-22 15:42 ?0次下載

    有限狀態機FSM在PLD中的實現分析

    本文通過舉例 利用VHDL 語言描述了不同模式的有限狀態機 分析了有限狀態機在 PLD 中綜合的特點 。
    發表于 03-22 15:41 ?3次下載

    有限狀態機的建模與優化設計

    本文提出一種優秀 、高效的 Verilog HDL 描述方式來進行有限狀態機設計 介紹有限狀態機的建模原則 并通過一個可綜合的實例 驗證了 該方法設計的有限狀態機在面積和功耗上的優
    發表于 03-22 15:19 ?1次下載

    VHDL有限狀態機設計-ST

    EDA的有限狀態機,廣義而言是指只要涉及觸發器的電路,無論電路大小都可以歸結為狀態機有限狀態機設計在學習EDA時是很重要的一章。
    發表于 06-08 16:46 ?3次下載

    初學者對有限狀態機(FSM)的設計的認識

    有限狀態機(FSM)是一種常見的電路,由時序電路和組合電路組成。設計有限狀態機的第一步是確定采用Moore狀態機還是采用Mealy狀態機
    發表于 02-11 13:51 ?4337次閱讀
    初學者對<b class='flag-5'>有限狀態機</b>(FSM)的設計的認識

    基于有限狀態機的Linux多點觸摸屏驅動設計劉斌

    基于有限狀態機的Linux多點觸摸屏驅動設計_劉斌
    發表于 03-15 08:00 ?0次下載

    如何使用FPGA實現序列檢測有限狀態機

    有限狀態機是絕大部分控制電路的核心結構, 是表示有限狀態以及在這些狀態之間轉移和動作等行為的數學模型。有限狀態機是指輸出取決于過去輸入部分
    發表于 11-04 17:17 ?12次下載
    如何使用FPGA實現序列檢測<b class='flag-5'>有限狀態機</b>

    基于事件驅動有限狀態機介紹

    ? 一、介紹 EFSM(event finite state machine,事件驅動有限狀態機),是一個基于事件驅動有限狀態機,主要應
    的頭像 發表于 11-16 15:29 ?2371次閱讀

    如何以面向對象的思想設計有限狀態機

    有限狀態機又稱有限狀態自動機,簡稱狀態機,是表示有限狀態以及在這些
    發表于 02-07 11:23 ?4次下載
    如何以面向對象的思想設計<b class='flag-5'>有限狀態機</b>

    一個基于事件驅動有限狀態機

    EFSM(event finite state machine,事件驅動有限狀態機),是一個基于事件驅動有限狀態機,主要應用于嵌入式設備的軟件系統中。 EFSM的設計原則是
    的頭像 發表于 08-30 09:28 ?894次閱讀
    一個基于事件<b class='flag-5'>驅動</b>的<b class='flag-5'>有限狀態機</b>

    有限狀態機分割設計

    有限狀態機分割設計,其實質就是一個狀態機分割成多個狀態機
    的頭像 發表于 10-09 10:47 ?662次閱讀

    基于有限狀態機的車身防盜報警的實現

    電子發燒友網站提供《基于有限狀態機的車身防盜報警的實現.pdf》資料免費下載
    發表于 10-26 09:48 ?0次下載
    基于<b class='flag-5'>有限狀態機</b>的車身防盜報警的實現
    主站蜘蛛池模板: 永久免费观看视频| 福利片第一页| 色播在线视频| 午夜 福利 视频| 午夜在线观看免费视频| 亚洲午夜免费| 日本黄页视频| www.天天干| 亚洲免费视频网址| 99久久综合国产精品免费| 亚洲合集综合久久性色| 色福利网站| 精品一区二区三区免费爱| 波多野结衣在线观看一区二区| 欧美成人aaa大片| 久久久中文| 99pao在线视频精品免费| 天天艹夜夜艹| 精品xxxxxbbbb欧美中文| 男女爱爱免费| 第九色| 日本高清免费一本视频在线观看| 2021久久精品国产99国产| 人人爽人人澡| 手机免费黄色网址| 好爽毛片一区二区三区四区 | h网站亚洲| 色偷偷91久久综合噜噜噜| 久久九九色| 天天干夜夜操| 视频在线精品| 亚洲mm8成为人影院| 成人国产精品一级毛片了| 最新激情网| 色婷婷狠狠久久综合五月| 色妞导航| 狠狠狠色丁香婷婷综合久久五月| 天天伊人| 激情五月激情综合| aaa在线观看视频高清视频| 男人j桶进女人免费视频|