吴忠躺衫网络科技有限公司

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

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

3天內不再提示

簡單的狀態機入門知識詳解

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2020-12-24 18:06 ? 次閱讀

大家晚上好,今天給大家分享一個篇關于狀態機的學習。為啥突然會寫這個話題,因為今天要看文章和視頻學習的時候,突然看到了“狀態機”三個字,也突然讓我想起了,在剛入職一家公司的時候,看產品的源代碼畫出整個軟件框架流程圖來,現在我還清晰的記得當時公司產品里面就有用到這個狀態機的用法,但是當時我剛接觸到這個東西,看了老半天那個源碼嗎,沒看懂,因為那時候第一次看那么大的工程量代碼,說實話腦袋有點暈暈的,不是很習慣。所以今天的文章只是帶大家入門和了解一下狀態機,等你真正在工作當中有遇到這個狀態機作為開發需要的話,你再去深入研究。

一、什么是狀態機?

1、有限狀態機:

常說的狀態機是有限狀態機FSM(Finite State Machine)。FSM指的是有有限個狀態(一般是一個狀態變量的值),這個機器同時能夠從外部接收信號信息輸入,機器在接收到外部輸入的信號后會綜合考慮當前自己的狀態和用戶輸入的信息,然后機器做出動作:跳轉到另一個狀態。

舉個實際生活例子來理解一下,比如我們平時燒開水喝,在你沒燒之前,水的狀態是液態的,但是當你把外界溫度一升高,水達到它的沸點之后,就會形成水蒸氣;當你把外界溫度降下來,水蒸氣就有會變成液態的水了。這里是外界條件是溫度,溫度的變化會引起水的狀態的變化。這個例子可以和我們的狀態機來做一個簡單的思想對比。

2、考慮狀態機的關鍵點:

從剛才的定義來看,我們只要抓住狀態機的關鍵點來理解就行:

1、外部輸入

2、當前狀態

3、下一個狀態

二、兩種狀態機類型:

(1)Moore型狀態機特點是:輸出只與當前狀態有關(與輸入信號無關)。相對簡單,考慮狀態機的下一個狀態時只需要考慮它的當前狀態就行了。

(2)Mealy型狀態機的特點是:輸出不只和當前狀態有關,還與輸入信號有關。狀態機接收到一個輸入信號需要跳轉到下一個狀態時,狀態機綜合考慮2個條件(當前狀態、輸入值)后才決定跳轉到哪個狀態。

三、狀態機的常見用途:

(1)電路設計中廣泛使用了狀態機思想。

(2)FPGA程序設計。

(3)軟件設計(框架類型的設計,譬如操作系統的GUI系統、消息機制)。

四、狀態機解決了什么問題:

(1)我們平時寫程序都是順序執行的,這種程序有個特點:程序的大體執行流程是既定的,程序的執行是遵照一定的大的方向有跡可尋的。

(2)但是偶爾會碰到這樣的程序:外部不一定會按照既定流程來給程序輸入信息,而程序還需要完全能夠接收并響應外部的這些輸入信號,還要能做出符合邏輯的輸出。

五、實戰例子:

開鎖狀態機。功能描述:用戶連續輸入正確的密碼則會開鎖,如果密碼輸入過程錯誤則鎖會退回到初始狀態重新計入密碼,即:用戶只需要連續輸入出正確的密碼即可開鎖(輸入錯誤不用撤銷、也不用刪除)。

#include <stdio.h>

// 給狀態機定義狀態集

typedef enum

STATE1,

STATE2,

STATE3,

STATE4,

STATE5,

STATE6,

STATE7,

}STATE;

int main(void)

int num = 0;

// current_state記錄狀態機的當前狀態,初始為STATE1,用戶每輸入一個正確的

// 密碼STATE就走一步,一直到STATE為STATE7后鎖就開了;其中只要有一次用戶

// 輸入對不上就回到STATE1.

STATE current_state = STATE1; // 狀態機初始狀態為STATE1

// 第一步:實現一個用戶循環輸入密碼的循環

printf("請輸入密碼,密碼正確開鎖.");

while (1)

scanf("%d", &num);

printf("num = %d.", num);

// 在這里處理用戶的本次輸入

switch (current_state)

case STATE1:

if (num == 1)

current_state = STATE2; // 用戶輸入對了一步,STATE走一步

else

current_state = STATE1;

break;

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

    關注

    2

    文章

    492

    瀏覽量

    27649
  • fsm
    fsm
    +關注

    關注

    0

    文章

    35

    瀏覽量

    12844
收藏 人收藏

    評論

    相關推薦

    Simulink中的狀態機建模方法 Simulink數據可視化與分析功能

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

    基于狀態機和面向對象的思想設計按鍵檢測模塊

    嵌入式入門學習的教程里面,按鍵原理普遍被認為是“很簡單”的知識點之一,按鍵輸入檢測的原理,無非就是通過CPU不斷掃描按鍵引腳的電平狀態,或者采用單片
    的頭像 發表于 11-14 11:44 ?346次閱讀
    基于<b class='flag-5'>狀態機</b>和面向對象的思想設計按鍵檢測模塊

    觸發器和狀態機的關系是什么

    觸發器和狀態機在數字電路設計中有著緊密的關系,它們共同構成了時序邏輯電路的基礎,用于實現數據的存儲、處理和傳輸。
    的頭像 發表于 08-12 11:24 ?546次閱讀

    如何在FPGA中實現狀態機

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

    玩轉Spring狀態機

    說起Spring狀態機,大家很容易聯想到這個狀態機和設計模式中狀態模式的區別是啥呢?沒錯,Spring狀態機就是狀態模式的一種實現,在介紹S
    的頭像 發表于 06-25 14:21 ?1030次閱讀
    玩轉Spring<b class='flag-5'>狀態機</b>

    關于SMU狀態機的問題求解

    我有一些關于 SMU 狀態機的問題。 假設由于某種原因,SMU 已進入故障狀態。 手冊指出,要返回運行狀態并將 FSP 恢復到無故障狀態,應調用IfxSmu_releaseFSP()。
    發表于 05-29 08:18

    使用系統滴答定時中斷,基于按鍵的狀態機怎么只能1個1個+,不能連+?

    使用系統滴答定時中斷,基于按鍵的狀態機怎么只能1個1個+,不能連+ #define KEY1_USERGPIO_ReadInputDataBit(GPIOC,GPIO_Pin_13
    發表于 05-16 06:27

    請問STM32F051用了操作系統RTX后還需要寫狀態機不?

    現在學會了rtx操作系統后,原來用狀態機的學的程序,可不可以不切割,直接單線程來執行列?各位前前輩指點一下。多謝!
    發表于 05-08 06:11

    在Verilog中實現Moore型和Mealy型狀態機的方法簡析

    編寫能夠被綜合工具識別的狀態機,首先需要理解狀態機的基本概念和分類。狀態機(FSM)是表示有限個狀態以及在這些狀態之間轉換的邏輯結構。
    的頭像 發表于 05-01 11:38 ?1800次閱讀

    嵌入式編程,如何用 C 語言實現狀態機設計?

    狀態機模式是一種行為模式,通過多態實現不同狀態的調轉行為的確是一種很好的方法,只可惜在嵌入式環境下,有時只能寫純C代碼,并且還需要考慮代碼的重入和多任務請求跳轉等情形,因此實現起來著實需要一番考慮
    發表于 04-23 11:00

    求助LabVIEW,狀態機里面反饋節點如何初始化問題

    求助labview,狀態機里面反饋節點如何初始化,下次執行這個狀態的時候初始化一次!謝謝謝謝!
    發表于 03-25 18:17

    如何采用“狀態機”解析UART數據幀

    如果一個系統接收上述“不定長度”的協議幀,將會有一個挑戰--如何高效接收與解析。 為簡化系統設計,我們強烈建議您采用“狀態機”來解析UART數據幀。
    的頭像 發表于 03-25 14:29 ?792次閱讀
    如何采用“<b class='flag-5'>狀態機</b>”解析UART數據幀

    請問GPIF狀態機的內部信號需要延遲才能斷言嗎?

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

    什么是有限狀態機?如何解決傳統有限狀態機狀態爆炸」問題?

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

    Verilog狀態機+設計實例

    在verilog中狀態機的一種很常用的邏輯結構,學習和理解狀態機的運行規律能夠幫助我們更好地書寫代碼,同時作為一種思想方法,在別的代碼設計中也會有所幫助。 一、簡介 在使用過程中我們常說
    的頭像 發表于 02-12 19:07 ?4343次閱讀
    Verilog<b class='flag-5'>狀態機</b>+設計實例
    百家乐官网游戏机压法| 德州扑克学校| 百家乐管理启发书| 真人百家乐官网网站接口| 大发888官方hgx2dafa888gwd| 真人百家乐现金游戏| 百家乐官网网站出售| 大发888官网e世博官方网站| 百家乐庄闲出现几率| 百家乐官网赌场在线娱乐| 阳西县| 真人百家乐官网| 棋牌百家乐官网程序破解| 百家乐官网家| 百家乐官网高手qq| 德州扑克单机版下载| 百家乐软件代理| 百家乐官网园是真的不| 广州百家乐官网赌场| 潼关县| 云鼎娱乐场送彩金| 百家乐那个平好| 大发百家乐现金| 实战百家乐官网十大取胜原因百分百战胜百家乐官网不买币不吹牛只你能做到按我说的.百家乐官网基本规则 | 百家乐破解仪| 百家乐线上真人游戏| 银河百家乐官网的玩法技巧和规则| 百家乐官网游戏机在哪有| BET365官方网| 大发888真人新浪微群| 旅百家乐赢钱律| 百家乐剁手| 百家乐在线怎么玩| 网络百家乐官网路子玩| 澳门百家乐官网是骗人的| 乌兰察布市| bet365怎么样| 大发888下载 客户端| 百家乐路单统| 免费百家乐平预测软件| 百家乐群博乐吧blb8v|