99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

簡單的狀態(tài)機入門知識詳解

電子設(shè)計 ? 來源:電子設(shè)計 ? 作者:電子設(shè)計 ? 2020-12-24 18:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

一、什么是狀態(tài)機?

1、有限狀態(tài)機:

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

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

2、考慮狀態(tài)機的關(guān)鍵點:

從剛才的定義來看,我們只要抓住狀態(tài)機的關(guān)鍵點來理解就行:

1、外部輸入

2、當(dāng)前狀態(tài)

3、下一個狀態(tài)

二、兩種狀態(tài)機類型:

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

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

三、狀態(tài)機的常見用途:

(1)電路設(shè)計中廣泛使用了狀態(tài)機思想。

(2)FPGA程序設(shè)計。

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

四、狀態(tài)機解決了什么問題:

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

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

五、實戰(zhàn)例子:

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

#include <stdio.h>

// 給狀態(tài)機定義狀態(tài)集

typedef enum

STATE1,

STATE2,

STATE3,

STATE4,

STATE5,

STATE6,

STATE7,

}STATE;

int main(void)

int num = 0;

// current_state記錄狀態(tài)機的當(dāng)前狀態(tài),初始為STATE1,用戶每輸入一個正確的

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

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

STATE current_state = STATE1; // 狀態(tài)機初始狀態(tài)為STATE1

// 第一步:實現(xiàn)一個用戶循環(huán)輸入密碼的循環(huán)

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;

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

    關(guān)注

    2

    文章

    493

    瀏覽量

    28235
  • fsm
    fsm
    +關(guān)注

    關(guān)注

    0

    文章

    35

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

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

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

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計之十:NVMe初始化狀態(tài)機設(shè)計

    1為NVMe配置初始化狀態(tài)機狀態(tài)轉(zhuǎn)移圖。各狀態(tài)的說明如下: 圖1NVMe初始化狀態(tài)轉(zhuǎn)移圖 IDLE:空閑狀態(tài),復(fù)位后的初始
    發(fā)表于 07-05 22:03

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計之八:PCIe初始化狀態(tài)機設(shè)計

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

    有可能在 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

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

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

    求助,關(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

    高速ssd存儲系統(tǒng)中數(shù)據(jù)緩存控制器流程控制設(shè)計

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

    Linux進程狀態(tài)詳解

    進程狀態(tài)是task_struct內(nèi)的一個整數(shù);進行:進程在調(diào)度隊列中,進程的狀態(tài)都是running,阻塞:等待某種設(shè)備或者資源就緒。進程是一個隊列,設(shè)備也是一個隊列,當(dāng)我們讀磁盤,讀網(wǎng)卡的時候,如果
    的頭像 發(fā)表于 04-01 09:46 ?435次閱讀
    Linux進程<b class='flag-5'>狀態(tài)</b><b class='flag-5'>詳解</b>

    如何快速入門PLD電路設(shè)計

    基本的數(shù)字邏輯概念,如與、或、非、異或等邏輯門。 布爾代數(shù) :掌握布爾代數(shù)的基本原理,這對于設(shè)計復(fù)雜的邏輯電路至關(guān)重要。 狀態(tài)機 :學(xué)習(xí)有限狀態(tài)機(F
    的頭像 發(fā)表于 01-20 09:48 ?888次閱讀

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

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

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

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

    【「數(shù)字IC設(shè)計入門」閱讀體驗】+目錄和前2章

    建模139 12.4條件操作建模141 12.5同步時序邏輯建模142 12.6通用移位寄存器145 12.7狀態(tài)機建模145 12.8交互狀態(tài)機147 12.9Moore有限狀態(tài)機建模150 12.10Mealy型有限
    發(fā)表于 10-10 17:12

    十天學(xué)會單片可能嗎?單片入門需要多久?

    學(xué)習(xí)單片的過程,就像學(xué)習(xí)任何其他技能一樣,不僅在于書本上的知識,更在于實踐和應(yīng)用的能力。許多人可能會問:十天能學(xué)會單片嗎?答案是:可以,但這取決于你所定義的“學(xué)會”到什么程度。首先,讓我們明確
    的頭像 發(fā)表于 09-05 08:00 ?2454次閱讀
    十天學(xué)會單片<b class='flag-5'>機</b>可能嗎?單片<b class='flag-5'>機</b><b class='flag-5'>入門</b>需要多久?

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

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

    如何在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)。這里,我們將詳細探討如何在FPG
    的頭像 發(fā)表于 07-18 15:57 ?1230次閱讀