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

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

1、外部輸入

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

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

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

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

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

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

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

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

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

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

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

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

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

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

#include <stdio.h>

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

typedef enum

STATE1,

STATE2,

STATE3,

STATE4,

STATE5,

STATE6,

STATE7,

}STATE;

int main(void)

int num = 0;

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

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

// 輸入對(duì)不上就回到STATE1.

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

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

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

while (1)

scanf("%d", &num);

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

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

switch (current_state)

case STATE1:

if (num == 1)

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

else

current_state = STATE1;

break;

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

    關(guān)注

    2

    文章

    493

    瀏覽量

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

    關(guān)注

    0

    文章

    35

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

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

    1為NVMe配置初始化狀態(tài)機(jī)狀態(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è)計(jì)之八:PCIe初始化狀態(tài)機(jī)設(shè)計(jì)

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

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

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

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

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

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

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

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

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

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

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

    基于FPGA的DS18B20數(shù)字溫度傳感器測溫實(shí)例

    本文將使用三段式狀態(tài)機(jī)(Moore型)的寫法來對(duì)DS18B20進(jìn)行測溫操作,以便了解DS18B20和熟悉三段式狀態(tài)機(jī)的寫法。
    的頭像 發(fā)表于 03-17 11:06 ?1473次閱讀
    基于FPGA的DS18B20數(shù)字溫度傳感器測溫實(shí)例

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

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

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

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

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

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

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

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

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

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

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

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

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

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