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

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

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

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

淺談狀態(tài)機(jī)的要素、分類

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 作者:嵌入式ARM ? 2020-10-20 17:27 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

說到單片機(jī)編程,不得不說到狀態(tài)機(jī),狀態(tài)機(jī)做為軟件編程的主要架構(gòu)已經(jīng)在各種語言中應(yīng)用,當(dāng)然包括C語言,在一個(gè)思路清晰而且高效的程序中,必然有狀態(tài)機(jī)的身影浮現(xiàn)。靈活的應(yīng)用狀態(tài)機(jī)不僅是程序更高效,而且可讀性和擴(kuò)展性也很好。狀態(tài)無處不在,狀態(tài)中有狀態(tài),只要掌握了這種思維,讓它成為您編程中的一種習(xí)慣,相信您會受益匪淺。

狀態(tài)機(jī)可歸納為4個(gè)要素,即現(xiàn)態(tài)、條件、動作、次態(tài)。這樣的歸納,主要是出于對狀態(tài)機(jī)的內(nèi)在因果聯(lián)系的考慮?!艾F(xiàn)態(tài)”和“條件”是因,“動作”和“次態(tài)”是果。詳解如下:

①現(xiàn)態(tài):是指當(dāng)前所處的狀態(tài)。

②條件:又稱為“事件”。當(dāng)一個(gè)條件被滿足,將會觸發(fā)一個(gè)動作,或者執(zhí)行一次狀態(tài)的遷移。

③動作:條件滿足后執(zhí)行的動作。動作執(zhí)行完畢后,可以遷移到新的狀態(tài),也可以仍舊保持原狀態(tài)。動作不是必需的,當(dāng)條件滿足后,也可以不執(zhí)行任何動作,直接遷移到新狀態(tài)。

④次態(tài):條件滿足后要遷往的新狀態(tài)?!按螒B(tài)”是相對于“現(xiàn)態(tài)”而言的,“次態(tài)”一旦被激活,就轉(zhuǎn)變成新的“現(xiàn)態(tài)”了。

如果我們進(jìn)一步歸納,把“現(xiàn)態(tài)”和“次態(tài)”統(tǒng)一起來,而把“動作”忽略(降格處理),則只剩下兩個(gè)最關(guān)鍵的要素,即:狀態(tài)、遷移條件。

狀態(tài)機(jī)的表示要領(lǐng)有許多種,我們可以用文字、圖形或表格的形式來表示一個(gè)狀態(tài)機(jī)。

舉個(gè)簡單的例子:就按鍵處理來說,擊鍵動作本身也可以看做一個(gè)狀態(tài)機(jī)。一個(gè)細(xì)小的擊鍵動作包含了:釋放、抖動、閉合、抖動和重新釋放等狀態(tài)。當(dāng)我們打開思路,把狀態(tài)機(jī)作為一種思想導(dǎo)入到程序中去時(shí),就會找到處理疑問的一條有效的捷徑。有時(shí)候用狀態(tài)機(jī)的思維去思考程序該干什么,比用控制流程的思維去思考,可能會更有效。這樣一來狀態(tài)機(jī)便有了更實(shí)際的功用。廢話不多說,實(shí)踐才是檢驗(yàn)真理的唯一標(biāo)準(zhǔn)。

也許有人覺得狀態(tài)機(jī)把問題復(fù)雜化了,其實(shí)做過軟件設(shè)計(jì)的人無形之中已經(jīng)在用狀態(tài)機(jī),下面就總結(jié)介紹幾種狀態(tài)機(jī)。

第一種:switch case結(jié)構(gòu)狀態(tài)機(jī)

switch()。

case1:。

if(not反復(fù)執(zhí)行狀態(tài)1)。

進(jìn)入1狀態(tài)前要做的準(zhǔn)備。

進(jìn)入1狀態(tài)的過程。

if(not反復(fù)執(zhí)行狀態(tài)1)。

離開狀態(tài)1的過程。

case2:。

...。

但這種方式不能很有效預(yù)定義所有的狀態(tài),也不能把這些狀態(tài)之間的切換過程合理的定義出來,“狀態(tài)”本身沒有一個(gè)合理的定義,幾乎是一種面向過程的方式,只過這種方式足夠簡單,也最容易讓人接受,缺點(diǎn)就沒有“狀態(tài)”的定義和指派功能,導(dǎo)致狀態(tài)的混亂,出現(xiàn)狀態(tài)處理重復(fù)代碼,甚至處理不一致的問題,按照OO的觀念,狀態(tài)描述本來就應(yīng)該是一種實(shí)體。

第二種狀態(tài)機(jī):ifelse語句結(jié)構(gòu)狀態(tài)機(jī)

這種狀態(tài)機(jī)相對靈活一點(diǎn),但對于一些大的項(xiàng)目,系統(tǒng)軟件設(shè)計(jì)會相對復(fù)雜。

以上2種狀態(tài)機(jī)是是大家接觸最多的,也是經(jīng)常用到的,這里不多說了。下面重點(diǎn)談?wù)劦谌N狀態(tài)機(jī)。

第三種狀態(tài)機(jī):消息觸發(fā)狀態(tài)機(jī)

該類型的狀態(tài)機(jī)實(shí)現(xiàn)方式也是很多的,形態(tài)多樣,但萬變不離其宗的就是狀態(tài)機(jī)的4要素及現(xiàn)態(tài)、條件、動作、次態(tài)。

下面介紹一種消息觸發(fā)類型的狀態(tài)機(jī)。

基于消息驅(qū)動的狀態(tài)機(jī)機(jī)制

原理:一旦有消息觸發(fā),系統(tǒng)服務(wù)函數(shù)立即尋找所在狀態(tài)的消息與消息處理函數(shù)對,找到后執(zhí)行消息處理函數(shù)

步驟:

1.添加消息與消息映射

BEGIN_MESSAGE_ MAP(Name,Count) :狀態(tài)機(jī)名,消息數(shù)

ADD_NEW_MSG_ITEM (Msg,OnMsg) :消息與消息處理函數(shù)

END_MESSAGE_MAP:結(jié)束

2.在這里注冊

BEGIN_Register_Task:頭

...

ADD_Register_Task(Name,Count):狀態(tài)機(jī)名,消息數(shù)

...

END_Register_Task:尾

1.劃分電子秤狀態(tài),完成以上步驟后,完成OnMsg消息處理函數(shù)

Void OnMsg(void)

{

}

說明:以上用宏完成,具體宏是如下定義:

#defineBEGIN_MESSAGE_MAP(Name,Count) constMSG_NODE_TYP MSG_node_Array_##Name[(Count)]={

#define ADD_NEW_MSG_ITEM(Msg,OnMsg) {Msg,OnMsg},

#define END_MESSAGE_MAP };

#define BEGIN_Register_Task const MSG_MAP TaskMap[TotalTask]={

#define ADD_Register_Task(Name,Count) {(MSG_NODE_TYP*)MSG_node_Array_##Name,Count},

#define END_Register_Task };

從以上代碼可知:

1. 添加消息與消息映射實(shí)際上是定義消息與消息處理函數(shù)對的數(shù)組,以形成一個(gè)表

2. 注冊狀態(tài)機(jī)實(shí)際上是把所有消息對數(shù)組的入口定義成一個(gè)數(shù)組,以形成一個(gè)表

消息是如何被執(zhí)行的?

分發(fā)消息

void Default_DisposeMessage(unsigned char *pMsg)

{

unsigned chari;

unsigned charcount=TaskMap[g_Status].cItemCount;//定位到狀態(tài)表

for(i=0;i

{

if(*pMsg==TaskMap[g_Status].pMsgItems.msg)//看能否匹配消息

{

TaskMap[g_Status].pMsgItems.pMsgFunc();//找到就執(zhí)行消息處理函數(shù)

return;

}

}

}

void DispatchMessage(unsigned char*pMsg)

{

if(*pMsg)

{

Default_DisposeMessage(pMsg);

}

}

核心函數(shù):消息處理中心

void Message_Dispose_Central(void)

{

BYTE Msg;

while(GetMessage(&Msg)) //獲取消息

{

TranslateMessage(&Msg); //解釋消息

DispatchMessage(&Msg); //分發(fā)消息

}

}

責(zé)任編輯:PSY

原文標(biāo)題:單片機(jī)裸奔之狀態(tài)機(jī)淺談

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

    關(guān)注

    6067

    文章

    44997

    瀏覽量

    650737
  • 狀態(tài)機(jī)
    +關(guān)注

    關(guān)注

    2

    文章

    493

    瀏覽量

    28264

原文標(biāo)題:單片機(jī)裸奔之狀態(tài)機(jī)淺談

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

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

    請問如何在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ī)需不需要重新配置?

    你好,請問視頻格式改變的話,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

    NVME控制器設(shè)計(jì)之指令控制

    指令控制模塊由一個(gè)指令信息緩存, 一個(gè)指令組裝狀態(tài)機(jī)和一個(gè) ID 池組成。 指令信息緩存中存放著由系統(tǒng)控制模塊寫入的待處理指令信息; 指令組裝狀態(tài)機(jī)獲取緩存的指令信息, 將其組裝成提交隊(duì)列條目寫入提交隊(duì)列中; ID 池則用于存放可使用的指令 ID。
    的頭像 發(fā)表于 04-24 10:22 ?293次閱讀
    NVME控制器設(shè)計(jì)之指令控制

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

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

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

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

    光刻機(jī)分類與原理

    本文主要介紹光刻機(jī)分類與原理。 ? 光刻機(jī)分類 光刻機(jī)分類方式很多。按半導(dǎo)體制造工序
    的頭像 發(fā)表于 01-16 09:29 ?2588次閱讀
    光刻<b class='flag-5'>機(jī)</b>的<b class='flag-5'>分類</b>與原理

    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 ?3023次閱讀

    晶體管工作狀態(tài)分類與分析

    MOSFET由源極(Source)、柵極(Gate)、漏極(Drain)和襯底(Substrate)組成。盡管它們的結(jié)構(gòu)不同,但晶體管的工作狀態(tài)分類是相似的。 晶體管的工作狀態(tài) 1. 放大
    的頭像 發(fā)表于 12-03 09:47 ?1831次閱讀

    《DNK210使用指南 -CanMV版 V1.0》第四十八章 自學(xué)習(xí)分類實(shí)驗(yàn)

    狀態(tài)機(jī)進(jìn)行自學(xué)習(xí)及分類過程 if state_machine.current_state == STATE.CLASSIFY:scores = []feature
    發(fā)表于 11-20 09:22

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

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

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

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