国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

    文章

    499

    瀏覽量

    29147
  • fsm
    fsm
    +關注

    關注

    0

    文章

    36

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    單片入門準備

    單片入門篇 1、學好電子技術基礎知識,如電路基礎、模擬電路、數字電路和微機原理。這幾門課程都是弱電類專業的必修課程,學會這些后能保證你看懂單片機電路、知道電路的設計思路和工作原理; 2、學習
    發表于 12-22 07:39

    條件判斷法來實現狀態機

    狀態用 switch—case 組織起來, 將事件也用switch—case 組織起來, 然后讓其中一個 switch—case 整體插入到另一個 switch—case 的每一個 case 項中
    發表于 12-09 08:18

    睿遠研究院丨IO-Link規范解讀(十一):ISDU狀態機與EVENT事件

    上篇我們介紹了ISDU的典型編碼格式和應用案例,本篇我們就來詳細介紹下,ISDU的狀態機,并把EVENT事件的邏輯,給大家好好解析下。 1主站ISDU狀態機 如上圖所示,ISDU的狀態機的核心
    的頭像 發表于 11-29 18:28 ?4724次閱讀
    睿遠研究院丨IO-Link規范解讀(十一):ISDU<b class='flag-5'>狀態機</b>與EVENT事件

    什么是狀態機

    什么是狀態機狀態機(state machine)有5個要素: 狀態(state) 遷移(transition) 事件(event) 動作(action) 條件(guard) 狀態
    發表于 11-27 08:15

    嵌入式開發為何經常用到狀態機架構

    一個管腳電平跳變或者一個串口數據,讓整個程序都不動的情況也讓我非常糾結,如果事件一直不發生電平跳變,你要等到世界末日么? 如果應用狀態機編程思想,程序只需要用全局變量記錄下工作狀態,就可以轉頭去干別的
    發表于 11-25 07:08

    睿遠研究院丨IO-Link規范解讀(八):M-Sequence Type 與消息處理狀態機

    丟棄,減少后端工作量。 那么今天我們就來深入研究下,消息處理模塊中提到的各類M-Sequence,以及主從站的消息處理狀態機! ? 1 M-Sequence Type 上回講到主站發出來的MC和CKT
    的頭像 發表于 11-07 16:18 ?6312次閱讀
    睿遠研究院丨IO-Link規范解讀(八):M-Sequence Type 與消息處理<b class='flag-5'>狀態機</b>

    睿遠研究院丨IO-Link規范解讀(六):主從站狀態機解析

    前言 書接上文,今天我們就來好好聊聊主從站的DL-Mode狀態機,還請各位童鞋前排坐好! 1主站狀態機解析 主站的DL-Mode狀態機有5個大狀態,也是我們很熟悉的 建立通信、開始、預
    的頭像 發表于 10-28 17:34 ?6199次閱讀
    睿遠研究院丨IO-Link規范解讀(六):主從站<b class='flag-5'>狀態機</b>解析

    JTAG標準的狀態機實現

    JTAG作為一項國際標準測試協議(IEEE1149.1兼容),主要用于芯片內部測試和調試。目前的主流芯片均支持JTAG協議,如DSP、FPGA、ARM、部分單片等。標準的JTAG接口是20Pin,但JTAG實際使用的只有4根信號線,再配合電源、地。
    的頭像 發表于 08-21 15:12 ?2711次閱讀
    JTAG標準的<b class='flag-5'>狀態機</b>實現

    請問如何在FX10上使用GPIF III狀態機 *.h 文件?

    LVCMOS 2 位 SlaveFIFO GPIF III 狀態機的演示中有一個 cy_gpif_header_lvcmos.h 文件。 我想知道如何使用.h文件,只需放入.h文件放入 FX10 項目? 您有它的用戶指南文檔嗎?
    發表于 07-16 08:17

    NVMe高速傳輸之擺脫XDMA設計之十:NVMe初始化狀態機設計

    1為NVMe配置初始化狀態機狀態轉移圖。各狀態的說明如下: 圖1NVMe初始化狀態轉移圖 IDLE:空閑狀態,復位后的初始
    發表于 07-05 22:03

    NVMe高速傳輸之擺脫XDMA設計之八:PCIe初始化狀態機設計

    PCIe配置初始化狀態機實現PCIe設備枚舉和配置空間初始化過程,在完成鏈路訓練后,使用DFS(深度優先搜索)算法枚舉PCIe總線上的設備,完成PCIe總線域的地址分配和設備的初始化。PCIe配置
    發表于 07-05 22:00

    有可能在 FX3 GPIF2 中創建兩個獨立的狀態機嗎?

    我想,如果我想通過 FX3 GPIF2 創建兩個獨立的傳輸流接口,我需要在 GPIF2 設計器中創建兩個獨立的狀態機,我是否有可能在 GPIF2 設計器中創建兩個獨立的狀態機
    發表于 05-20 06:14

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

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

    求助,關于srammaster.cydsn中狀態機的問題求解

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

    高速ssd存儲系統中數據緩存控制器流程控制設計

    高速SSD系統中流程控制模塊設計。該模塊主要由寄存器、讀狀態機、寫狀態機和命令生成模塊組成,系統介紹各模塊功能。
    的頭像 發表于 04-14 10:43 ?827次閱讀
    高速ssd存儲系統中數據緩存控制器流程控制設計