吴忠躺衫网络科技有限公司

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

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

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

狀態(tài)機(jī)編程都有哪些優(yōu)點(diǎn)?

奈因PCB電路板設(shè)計(jì) ? 來源:STM32嵌入式開發(fā) ? 作者:STM32嵌入式開發(fā) ? 2021-07-27 11:05 ? 次閱讀

本文總結(jié)下狀態(tài)機(jī)編程的優(yōu)點(diǎn)。

提高CPU使用效率

話說我只要見到滿篇都是delay_ms()的程序就會頭疼,動輒十幾個(gè)ms幾十個(gè)ms的軟件延時(shí)是對CPU資源的巨大浪費(fèi),寶貴的CPU時(shí)間都浪費(fèi)在了NOP指令上。那種為了等待一個(gè)管腳電平跳變或者一個(gè)串口數(shù)據(jù),讓整個(gè)程序都不動的情況也讓我非常糾結(jié),如果事件一直不發(fā)生電平跳變,你要等到世界末日么?

如果應(yīng)用狀態(tài)機(jī)編程思想,程序只需要用全局變量記錄下工作狀態(tài),就可以轉(zhuǎn)頭去干別的工作了,當(dāng)然忙完那些活兒之后要再看看工作狀態(tài)有沒有變化。只要目標(biāo)事件(定時(shí)未到、電平?jīng)]跳變、串口數(shù)據(jù)沒收完)還沒發(fā)生,工作狀態(tài)就不會改變,程序就一直重復(fù)著“查詢—干別的—查詢—干別的”這樣的循環(huán),這樣CPU就閑不下來了。

這種處理方法的實(shí)質(zhì)就是在程序等待事件的過程中間隔性地插入一些有意義的工作,好讓CPU不是一直無謂地等待。

邏輯完備性

邏輯完備性是狀態(tài)機(jī)編程最大的優(yōu)點(diǎn)。

不知道大家有沒有用C語言寫過計(jì)算器的小程序,我很早以前寫過,寫出來一測試,那個(gè)慘不忍睹啊!當(dāng)我規(guī)規(guī)矩矩的輸入算式的時(shí)候,程序可以得到正確的計(jì)算結(jié)果,但要是故意輸入數(shù)字和運(yùn)算符號的隨意組合,程序總是得出莫名其妙的結(jié)果。

后來我試著思維模擬一下程序的工作過程,正確的算式思路清晰,流程順暢,可要碰上了不規(guī)矩的式子,走著走著我就暈菜了,那么多的標(biāo)志位,那么多的變量,變來變?nèi)ィ詈笾苯臃治霾幌氯チ恕?/p>

很久之后我認(rèn)識了狀態(tài)機(jī),才恍然明白,當(dāng)時(shí)的程序是有邏輯漏洞的。如果把這個(gè)計(jì)算器程序當(dāng)做是一個(gè)反應(yīng)式系統(tǒng),那么一個(gè)數(shù)字或者運(yùn)算符就可以看做一個(gè)事件,一個(gè)算式就是一組事件組合。對于一個(gè)邏輯完備的反應(yīng)式系統(tǒng),不管什么樣的事件組合,系統(tǒng)都能正確處理事件,而且系統(tǒng)自身的工作狀態(tài)也一直處在可知可控的狀態(tài)中。反過來,如果一個(gè)系統(tǒng)的邏輯功能不完備,在某些特定事件組合的驅(qū)動下,系統(tǒng)就會進(jìn)入一個(gè)不可知不可控的狀態(tài),與設(shè)計(jì)者的意圖相悖。

狀態(tài)機(jī)就能解決邏輯完備性的問題。

狀態(tài)機(jī)是一種以系統(tǒng)狀態(tài)為中心,以事件為變量的設(shè)計(jì)方法,它專注于各個(gè)狀態(tài)的特點(diǎn)以及狀態(tài)之間相互轉(zhuǎn)換的關(guān)系。狀態(tài)的轉(zhuǎn)換恰恰是事件引起的,那么在研究某個(gè)具體狀態(tài)的時(shí)候,我們自然而然地會考慮任何一個(gè)事件對這個(gè)狀態(tài)有什么樣的影響。這樣,每一個(gè)狀態(tài)中發(fā)生的每一個(gè)事件都會在我們的考慮之中,也就不會留下邏輯漏洞。

這樣說也許大家會覺得太空洞,實(shí)踐出真知,某天如果你真的要設(shè)計(jì)一個(gè)邏輯復(fù)雜的程序,會覺得狀態(tài)機(jī)真香!

程序結(jié)構(gòu)清晰

用狀態(tài)機(jī)寫出來的程序的結(jié)構(gòu)是非常清晰的。

程序員最痛苦的事兒莫過于讀別人寫的代碼。如果代碼不是很規(guī)范,而且手里還沒有流程圖,讀代碼會讓人暈了又暈,只有順著程序一遍又一遍的看,很多遍之后才能隱約地明白程序大體的工作過程。有流程圖會好一點(diǎn),但是如果程序比較大,流程圖也不會畫得多詳細(xì),很多細(xì)節(jié)上的過程還是要從代碼中理解。

相比之下,用狀態(tài)機(jī)寫的程序要好很多,拿一張標(biāo)準(zhǔn)的UML狀態(tài)轉(zhuǎn)換圖,再配上一些簡明的文字說明,程序中的各個(gè)要素一覽無余。程序中有哪些狀態(tài),會發(fā)生哪些事件,狀態(tài)機(jī)如何響應(yīng),響應(yīng)之后跳轉(zhuǎn)到哪個(gè)狀態(tài),這些都十分明朗,甚至許多動作細(xì)節(jié)都能從狀態(tài)轉(zhuǎn)換圖中找到。可以毫不夸張的說,有了UML狀態(tài)轉(zhuǎn)換圖,程序流程圖寫都不用寫。

來源:STM32嵌入式開發(fā)

版權(quán)歸原作者所有,如有侵權(quán),請聯(lián)系刪除。

編輯:jq

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

    關(guān)注

    88

    文章

    3637

    瀏覽量

    93986

原文標(biāo)題:總結(jié)一下狀態(tài)機(jī)編程的優(yōu)點(diǎn)

文章出處:【微信號:pcbgood,微信公眾號:奈因PCB電路板設(shè)計(jì)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

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

    觸發(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 ?546次閱讀

    如何在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),決定下一步的動作和新的
    的頭像 發(fā)表于 07-18 15:57 ?729次閱讀

    玩轉(zhuǎn)Spring狀態(tài)機(jī)

    說起Spring狀態(tài)機(jī),大家很容易聯(lián)想到這個(gè)狀態(tài)機(jī)和設(shè)計(jì)模式中狀態(tài)模式的區(qū)別是啥呢?沒錯,Spring狀態(tài)機(jī)就是狀態(tài)模式的一種實(shí)現(xiàn),在介紹S
    的頭像 發(fā)表于 06-25 14:21 ?1030次閱讀
    玩轉(zhuǎn)Spring<b class='flag-5'>狀態(tài)機(jī)</b>

    關(guān)于SMU狀態(tài)機(jī)的問題求解

    我有一些關(guān)于 SMU 狀態(tài)機(jī)的問題。 假設(shè)由于某種原因,SMU 已進(jìn)入故障狀態(tài)。 手冊指出,要返回運(yùn)行狀態(tài)并將 FSP 恢復(fù)到無故障狀態(tài),應(yīng)調(diào)用IfxSmu_releaseFSP()。
    發(fā)表于 05-29 08:18

    使用系統(tǒng)滴答定時(shí)中斷,基于按鍵的狀態(tài)機(jī)怎么只能1個(gè)1個(gè)+,不能連+?

    使用系統(tǒng)滴答定時(shí)中斷,基于按鍵的狀態(tài)機(jī)怎么只能1個(gè)1個(gè)+,不能連+ #define KEY1_USERGPIO_ReadInputDataBit(GPIOC,GPIO_Pin_13
    發(fā)表于 05-16 06:27

    請問STM32F051用了操作系統(tǒng)RTX后還需要寫狀態(tài)機(jī)不?

    現(xiàn)在學(xué)會了rtx操作系統(tǒng)后,原來用狀態(tài)機(jī)的學(xué)的程序,可不可以不切割,直接單線程來執(zhí)行列?各位前前輩指點(diǎn)一下。多謝!
    發(fā)表于 05-08 06:11

    在Verilog中實(shí)現(xiàn)Moore型和Mealy型狀態(tài)機(jī)的方法簡析

    編寫能夠被綜合工具識別的狀態(tài)機(jī),首先需要理解狀態(tài)機(jī)的基本概念和分類。狀態(tài)機(jī)(FSM)是表示有限個(gè)狀態(tài)以及在這些狀態(tài)之間轉(zhuǎn)換的邏輯結(jié)構(gòu)。
    的頭像 發(fā)表于 05-01 11:38 ?1800次閱讀

    嵌入式編程,如何用 C 語言實(shí)現(xiàn)狀態(tài)機(jī)設(shè)計(jì)?

    狀態(tài)機(jī)模式是一種行為模式,通過多態(tài)實(shí)現(xiàn)不同狀態(tài)的調(diào)轉(zhuǎn)行為的確是一種很好的方法,只可惜在嵌入式環(huán)境下,有時(shí)只能寫純C代碼,并且還需要考慮代碼的重入和多任務(wù)請求跳轉(zhuǎn)等情形,因此實(shí)現(xiàn)起來著實(shí)需要一番考慮
    發(fā)表于 04-23 11:00

    求助LabVIEW,狀態(tài)機(jī)里面反饋節(jié)點(diǎn)如何初始化問題

    求助labview,狀態(tài)機(jī)里面反饋節(jié)點(diǎn)如何初始化,下次執(zhí)行這個(gè)狀態(tài)的時(shí)候初始化一次!謝謝謝謝!
    發(fā)表于 03-25 18:17

    如何采用“狀態(tài)機(jī)”解析UART數(shù)據(jù)幀

    如果一個(gè)系統(tǒng)接收上述“不定長度”的協(xié)議幀,將會有一個(gè)挑戰(zhàn)--如何高效接收與解析。 為簡化系統(tǒng)設(shè)計(jì),我們強(qiáng)烈建議您采用“狀態(tài)機(jī)”來解析UART數(shù)據(jù)幀。
    的頭像 發(fā)表于 03-25 14:29 ?792次閱讀
    如何采用“<b class='flag-5'>狀態(tài)機(jī)</b>”解析UART數(shù)據(jù)幀

    關(guān)于FX3使用4個(gè)線程進(jìn)行FPGA到USB的數(shù)據(jù)傳輸-狀態(tài)機(jī)設(shè)置的問題求解

    狀態(tài)機(jī)進(jìn)行測試 其中WAIT到TH0的轉(zhuǎn)移條件Buffer_Ready是一個(gè)外部輸入信號,TH0到TH3是4個(gè)線程,我在固件中為每個(gè)線程都設(shè)置了一個(gè)Bulk In endpoint,在測試時(shí)發(fā)現(xiàn)
    發(fā)表于 02-27 06:40

    請問GPIF狀態(tài)機(jī)的內(nèi)部信號需要延遲才能斷言嗎?

    dma_wm_thn 這樣的過渡觸發(fā)器需要一些周期的延遲才能斷言嗎? 在我的實(shí)踐中,DMA_WM_THN 觸發(fā)器似乎有 1 個(gè)時(shí)鐘周期延遲: ? 圖像是我的狀態(tài)機(jī)的一部分,數(shù)據(jù)總線是 32 位
    發(fā)表于 02-23 07:43

    什么是有限狀態(tài)機(jī)?如何解決傳統(tǒng)有限狀態(tài)機(jī)狀態(tài)爆炸」問題?

    有限狀態(tài)機(jī)(Finite State Machine,簡稱FSM)是一種用來進(jìn)行對象行為建模的工具,其作用主要是描述對象在它的生命周期內(nèi)所經(jīng)歷的狀態(tài)序列以及如何響應(yīng)來自外界的各種事件。
    的頭像 發(fā)表于 02-17 16:09 ?6364次閱讀
    什么是有限<b class='flag-5'>狀態(tài)機(jī)</b>?如何解決傳統(tǒng)有限<b class='flag-5'>狀態(tài)機(jī)</b>「<b class='flag-5'>狀態(tài)</b>爆炸」問題?

    Verilog狀態(tài)機(jī)+設(shè)計(jì)實(shí)例

    在verilog中狀態(tài)機(jī)的一種很常用的邏輯結(jié)構(gòu),學(xué)習(xí)和理解狀態(tài)機(jī)的運(yùn)行規(guī)律能夠幫助我們更好地書寫代碼,同時(shí)作為一種思想方法,在別的代碼設(shè)計(jì)中也會有所幫助。 一、簡介 在使用過程中我們常說
    的頭像 發(fā)表于 02-12 19:07 ?4342次閱讀
    Verilog<b class='flag-5'>狀態(tài)機(jī)</b>+設(shè)計(jì)實(shí)例
    金银岛娱乐城开户| 百家乐娱乐城代理| 大发888娱乐城下载平台| 百家乐官网实时赌博| 百家乐赌博网址| 时时博娱乐城| 百家乐娱乐官方网| 元谋县| 菲律宾百家乐娱乐平台| 百家乐官网游戏怎么刷钱| 百家乐tt娱乐网| 百家乐官网在线小游戏| 百家乐二号博彩正网| 天下足球网| 百家乐数据程序| 临桂县| 百家乐的桌布| 任我赢百家乐官网自动投注分析系统 | 百家乐隐者博客| 静乐县| 御匾会百家乐娱乐城| 百家乐官网桌蓝盾在线| 百家乐和局投注法| 百家乐官网庄和闲的赌法| 大发888游戏免费下载| 拉斯维加斯娱乐| 最新百家乐出千赌具| 百家乐官网赢率| 博彩e族论坛| 百家乐程序软件| 百家乐官网线上游戏| 百家乐是个什么样的游戏 | 百家乐官网骗局视频| 最好的棋牌游戏大厅| 新2百家乐娱乐城| 大世界百家乐官网现金网| 大发888娱乐软件| 百家乐娱乐城博彩正网| 百家乐官网全讯网娱乐城| 中华德州扑克协会| 百家乐赌博博彩赌博网|