一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

使用函數(shù)指針的方法實現(xiàn)狀態(tài)機

GReq_mcu168 ? 來源:玩轉(zhuǎn)單片機 ? 作者:玩轉(zhuǎn)單片機 ? 2020-10-19 09:36 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

之前寫過一篇狀態(tài)機的實用文章,很多朋友說有幾個地方有點難度不易理解,今天給大家換種簡單寫法,使用函數(shù)指針的方法實現(xiàn)狀態(tài)機。

狀態(tài)機簡介

有限狀態(tài)機FSM是有限個狀態(tài)及在這些狀態(tài)之間的轉(zhuǎn)移和動作等行為的數(shù)學(xué)模型,是一種邏輯單元內(nèi)部的高效編程方法,可以根據(jù)不同狀態(tài)或者消息類型進(jìn)行相應(yīng)的處理邏輯,使得程序邏輯清晰易懂。

函數(shù)指針實現(xiàn)FSM

使用函數(shù)指針實現(xiàn)FSM可以分為3個步驟

建立相應(yīng)的狀態(tài)表和動作查詢表

根據(jù)狀態(tài)表、事件、動作表定位相應(yīng)的動作處理函數(shù)

執(zhí)行完成后再進(jìn)行狀態(tài)的切換

代碼實現(xiàn)步驟

定義狀態(tài)數(shù)據(jù)的枚舉類型

typedefenum{ state_1=1, state_2, state_3, state_4 }State;

定義事件的枚舉類型

typedefenum{ event_1=1, event_2, event_3, event_4, event_5 }EventID;

定義狀態(tài)表的數(shù)據(jù)類型

typedefstruct { intevent;//事件 intCurState;//當(dāng)前狀態(tài) void(*eventActFun)();//函數(shù)指針 intNextState;//下一個狀態(tài) }StateTable;

定義處理函數(shù)及建立狀態(tài)表

voidf121() { printf("thisisf121 "); } voidf221() { printf("thisisf221 "); } voidf321() { printf("thisisf321 "); } voidf122() { printf("thisisf122 "); } StateTablefTable[]= { //{到來的事件,當(dāng)前的狀態(tài),將要要執(zhí)行的函數(shù),下一個狀態(tài)} {event_1,state_1,f121,event_2}, {event_2,state_2,f221,event_3}, {event_3,state_3,f321,event_4}, {event_4,state_4,f122,event_1}, //addyourcodehere };

狀態(tài)機類型,及狀態(tài)機接口函數(shù)

/*狀態(tài)機類型*/ typedefstruct{ intcurState;//當(dāng)前狀態(tài) StateTable*stateTable;//狀態(tài)表 intsize;//表的項數(shù) }fsmType; /*狀態(tài)機注冊,給它一個狀態(tài)表*/ voidfsmRegist(fsmType*pFsm,StateTable*pTable) { pFsm->stateTable=pTable; } /*狀態(tài)遷移*/ voidfsmStateTransfer(fsmType*pFsm,intstate) { pFsm->curState=state; } /*事件處理*/ voidfsmEventHandle(fsmType*pFsm,intevent) { StateTable*pActTable=pFsm->stateTable; void(*eventActFun)()=NULL;//函數(shù)指針初始化為空 intNextState; intCurState=pFsm->curState; intmaxNum=pFsm->size; intflag=0;//標(biāo)識是否滿足條件 /*獲取當(dāng)前動作函數(shù)*/ for(inti=0;i

附代碼

代碼直接復(fù)制過去就行啦,本想打包的,太麻煩了。

測試程序

//編譯器:http://www.dooccn.com/cpp/ //來源:技術(shù)讓夢想更偉大 //作者:李肖遙 #include typedefenum{ state_1=1, state_2, state_3, state_4 }State; typedefenum{ event_1=1, event_2, event_3, event_4, event_5 }EventID; typedefstruct{ intevent;//事件 intCurState;//當(dāng)前狀態(tài) void(*eventActFun)();//函數(shù)指針 intNextState;//下一個狀態(tài) }StateTable; voidf121() { printf("thisisf121 "); } voidf221() { printf("thisisf221 "); } voidf321() { printf("thisisf321 "); } voidf122() { printf("thisisf122 "); } StateTablefTable[]= { //{到來的事件,當(dāng)前的狀態(tài),將要要執(zhí)行的函數(shù),下一個狀態(tài)} {event_1,state_1,f121,event_2}, {event_2,state_2,f221,event_3}, {event_3,state_3,f321,event_4}, {event_4,state_4,f122,event_1}, //addyourcodehere }; /*狀態(tài)機類型*/ typedefstruct{ intcurState;//當(dāng)前狀態(tài) StateTable*stateTable;//狀態(tài)表 intsize;//表的項數(shù) }fsmType; /*狀態(tài)機注冊,給它一個狀態(tài)表*/ voidfsmRegist(fsmType*pFsm,StateTable*pTable) { pFsm->stateTable=pTable; } /*狀態(tài)遷移*/ voidfsmStateTransfer(fsmType*pFsm,intstate) { pFsm->curState=state; } /*事件處理*/ voidfsmEventHandle(fsmType*pFsm,intevent) { StateTable*pActTable=pFsm->stateTable; void(*eventActFun)()=NULL;//函數(shù)指針初始化為空 intNextState; intCurState=pFsm->curState; intmaxNum=pFsm->size; intflag=0;//標(biāo)識是否滿足條件 /*獲取當(dāng)前動作函數(shù)*/ for(inti=0;i

編譯結(jié)果

總結(jié)

使用函數(shù)指針實現(xiàn)的FSM的過程還是比較費時費力的,但是這一切相對一大堆的if/else、switch/case來說都是值得的,當(dāng)你的程序規(guī)模變得越來越大的時候,基于這種表結(jié)構(gòu)的狀態(tài)機,維護(hù)程序起來會清晰很多。

原文標(biāo)題:【編程之美】函數(shù)指針方法實現(xiàn)簡單狀態(tài)機(附代碼)

文章出處:【微信公眾號:玩轉(zhuǎn)單片機】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

責(zé)任編輯:haq

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

    關(guān)注

    88

    文章

    3686

    瀏覽量

    95030
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4376

    瀏覽量

    64534
  • 指針
    +關(guān)注

    關(guān)注

    1

    文章

    484

    瀏覽量

    71097

原文標(biāo)題:【編程之美】函數(shù)指針方法實現(xiàn)簡單狀態(tài)機(附代碼)

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    有可能在 FX3 GPIF2 中創(chuàng)建兩個獨立的狀態(tài)機嗎?

    我想,如果我想通過 FX3 GPIF2 創(chuàng)建兩個獨立的傳輸流接口,我需要在 GPIF2 設(shè)計器中創(chuàng)建兩個獨立的狀態(tài)機,我是否有可能在 GPIF2 設(shè)計器中創(chuàng)建兩個獨立的狀態(tài)機?
    發(fā)表于 05-20 06:14

    [Actor] 通過actor創(chuàng)建控制中心與數(shù)據(jù)采集工作站來看操作者架構(gòu)

    *附件:面向?qū)ο笤囼?b class='flag-5'>機測控系統(tǒng).zip 一、actor對象描述 1、actor對象本身就是一個隊列狀態(tài)機類,空白的一個對象即具備了隊列狀態(tài)機功能。但是具備不代表無條件立即運行;這些功能必須在幾個關(guān)鍵
    發(fā)表于 05-14 18:44

    cypress3014視頻格式改變的話,GPIF狀態(tài)機需不需要重新配置?

    你好,請問視頻格式改變的話,GPIF狀態(tài)機需不需要重新配置
    發(fā)表于 05-14 07:28

    [Actor]在程序框圖編程時,如何操作消息和方法對應(yīng)的VI

    actor應(yīng)用的關(guān)鍵: 當(dāng)在程序框圖編程時,核心是針對“消息”vi 進(jìn)行操作,并不操作消息對應(yīng)的方法vi(具體要實現(xiàn)的功能)。 調(diào)用的消息vi時,后臺自動調(diào)用對應(yīng)方法vi。 相當(dāng)于在隊列狀態(tài)機
    發(fā)表于 05-13 18:10

    求助,關(guān)于srammaster.cydsn中狀態(tài)機的問題求解

    晚上好。 我目前正在學(xué)習(xí) GPIF II。 查看..EZ-USB FX3 SDK1.3firmwaregpif_examplescyfxsrammastersrammaster.cydsn中的狀態(tài)機,有狀態(tài)START和START1。 這意味著什么?
    發(fā)表于 05-12 06:20

    NVME控制器之隊列管理模塊

    時,表示隊列為滿;當(dāng)Head指針等于Tail指針時,表示隊列為空。該模塊中的狀態(tài)機用來實現(xiàn)門鈴寄存器信息更新的流程控制工作。隊列管理狀態(tài)機
    發(fā)表于 05-03 20:19

    函數(shù)指針的六個常見應(yīng)用場景

    函數(shù)指針在嵌入式開發(fā)中有著廣泛的應(yīng)用,它讓代碼更加靈活,減少冗余,提高可擴展性。很多時候,我們需要根據(jù)不同的情況動態(tài)調(diào)用不同的函數(shù),而函數(shù)指針
    的頭像 發(fā)表于 04-07 11:58 ?424次閱讀
    <b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>的六個常見應(yīng)用場景

    CSU-IDE是否支持函數(shù)指針

    在編寫代碼過程中需要使用函數(shù)指針,編譯的時候報不支持,請問是需要設(shè)置,還是軟件本身就不支持
    發(fā)表于 12-22 23:02

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

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

    基于狀態(tài)機和面向?qū)ο蟮乃枷朐O(shè)計按鍵檢測模塊

    嵌入式入門學(xué)習(xí)的教程里面,按鍵原理普遍被認(rèn)為是“很簡單”的知識點之一,按鍵輸入檢測的原理,無非就是通過CPU不斷掃描按鍵引腳的電平狀態(tài),或者采用單片引腳外部中斷方式,然后在死循環(huán)或者中斷服務(wù)程序里面處理按鍵被按下
    的頭像 發(fā)表于 11-14 11:44 ?930次閱讀
    基于<b class='flag-5'>狀態(tài)機</b>和面向?qū)ο蟮乃枷朐O(shè)計按鍵檢測模塊

    C語言指針詳細(xì)解析

    函數(shù)入?yún)⒍际窍嗤?,這時候如果要調(diào)用不同的排序方法,就可以使用指針函數(shù)實現(xiàn),我們只需要修改函數(shù)
    發(fā)表于 09-14 10:03

    時序邏輯電路的描述方法有哪些

    圖、狀態(tài)表、有限狀態(tài)機、卡諾圖、布爾差分方程、布爾函數(shù)、時序邏輯仿真等。 狀態(tài)狀態(tài)圖是一種圖形化的描述
    的頭像 發(fā)表于 08-28 11:37 ?1346次閱讀

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

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

    面試???1:函數(shù)指針指針函數(shù)、數(shù)組指針指針數(shù)組

    在嵌入式開發(fā)領(lǐng)域,函數(shù)指針、指針函數(shù)、數(shù)組指針指針數(shù)組是一些非常重要但又容易混淆的概念。理解它
    的頭像 發(fā)表于 08-10 08:11 ?1409次閱讀
    面試???1:<b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>與<b class='flag-5'>指針</b><b class='flag-5'>函數(shù)</b>、數(shù)組<b class='flag-5'>指針</b>與<b class='flag-5'>指針</b>數(shù)組

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

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