91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级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)榻裉煲次恼潞鸵曨l學(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

    文章

    499

    瀏覽量

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

    關(guān)注

    0

    文章

    36

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    單片機(jī)入門準(zhǔn)備

    單片機(jī)入門篇 1、學(xué)好電子技術(shù)基礎(chǔ)知識(shí),如電路基礎(chǔ)、模擬電路、數(shù)字電路和微機(jī)原理。這幾門課程都是弱電類專業(yè)的必修課程,學(xué)會(huì)這些后能保證你看懂單片機(jī)電路、知道電路的設(shè)計(jì)思路和工作原理; 2、學(xué)習(xí)
    發(fā)表于 12-22 07:39

    條件判斷法來實(shí)現(xiàn)狀態(tài)機(jī)

    狀態(tài)用 switch—case 組織起來, 將事件也用switch—case 組織起來, 然后讓其中一個(gè) switch—case 整體插入到另一個(gè) switch—case 的每一個(gè) case 項(xiàng)中
    發(fā)表于 12-09 08:18

    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(十一):ISDU狀態(tài)機(jī)與EVENT事件

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

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

    什么是狀態(tài)機(jī)? 狀態(tài)機(jī)(state machine)有5個(gè)要素: 狀態(tài)(state) 遷移(transition) 事件(event) 動(dòng)作(action) 條件(guard) 狀態(tài)
    發(fā)表于 11-27 08:15

    嵌入式開發(fā)為何經(jīng)常用到狀態(tài)機(jī)架構(gòu)

    一個(gè)管腳電平跳變或者一個(gè)串口數(shù)據(jù),讓整個(gè)程序都不動(dòng)的情況也讓我非常糾結(jié),如果事件一直不發(fā)生電平跳變,你要等到世界末日么? 如果應(yīng)用狀態(tài)機(jī)編程思想,程序只需要用全局變量記錄下工作狀態(tài),就可以轉(zhuǎn)頭去干別的
    發(fā)表于 11-25 07:08

    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(八):M-Sequence Type 與消息處理狀態(tài)機(jī)

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

    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(六):主從站狀態(tài)機(jī)解析

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

    JTAG標(biāo)準(zhǔn)的狀態(tài)機(jī)實(shí)現(xiàn)

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

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

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

    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 ?826次閱讀
    高速ssd存儲(chǔ)系統(tǒng)中數(shù)據(jù)緩存控制器流程控制設(shè)計(jì)