chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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)是什么

技術(shù)讓夢想更偉大 ? 來源:技術(shù)讓夢想更偉大 ? 2023-02-11 09:56 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

提高CPU使用效率

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

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

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

邏輯完備性

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

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

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

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

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

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

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

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

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

程序員最痛苦的事兒莫過于讀別人寫的代碼。關(guān)于文檔、注釋的重要性以及如何去寫。

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

相比之下,用狀態(tài)機(jī)寫的程序要好很多,拿一張標(biāo)準(zhǔn)的UML狀態(tài)轉(zhuǎn)換圖,再配上一些簡明的文字說明,程序中的各個要素一覽無余。程序中有哪些狀態(tài),會發(fā)生哪些事件,狀態(tài)機(jī)如何響應(yīng),響應(yīng)之后跳轉(zhuǎn)到哪個狀態(tài),這些都十分明朗,甚至許多動作細(xì)節(jié)都能從狀態(tài)轉(zhuǎn)換圖中找到??梢院敛豢鋸埖恼f,有了UML狀態(tài)轉(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)投訴
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3689

    瀏覽量

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

    關(guān)注

    2

    文章

    493

    瀏覽量

    28223

原文標(biāo)題:談?wù)劆顟B(tài)機(jī)編程的優(yōu)點(diǎn)

文章出處:【微信號:技術(shù)讓夢想更偉大,微信公眾號:技術(shù)讓夢想更偉大】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

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

    狀態(tài)機(jī)編程實(shí)例-狀態(tài)表法

    上篇文章,使用嵌套switch-case法的狀態(tài)機(jī)編程,實(shí)現(xiàn)了一個炸彈拆除小游戲。本篇,繼續(xù)介紹狀態(tài)機(jī)編程的第二種方法:狀態(tài)表法,來實(shí)現(xiàn)炸彈
    的頭像 發(fā)表于 06-20 09:05 ?2755次閱讀
    <b class='flag-5'>狀態(tài)機(jī)</b><b class='flag-5'>編程</b>實(shí)例-<b class='flag-5'>狀態(tài)</b>表法

    狀態(tài)機(jī)編程實(shí)例-嵌套switch-case法

    嵌入式軟件開發(fā)中,狀態(tài)機(jī)編程是一個比較實(shí)用的代碼實(shí)現(xiàn)方式,特別適用于事件驅(qū)動的系統(tǒng)。本篇,以一個炸彈拆除的小游戲?yàn)槔榻B狀態(tài)機(jī)編程的思路。
    的頭像 發(fā)表于 06-15 09:01 ?2458次閱讀
    <b class='flag-5'>狀態(tài)機(jī)</b><b class='flag-5'>編程</b>實(shí)例-嵌套switch-case法

    狀態(tài)機(jī)編程實(shí)例-面向?qū)ο蟮?b class='flag-5'>狀態(tài)設(shè)計(jì)模式

    本編介紹了狀態(tài)機(jī)編程的第3種方法——面向?qū)ο蟮?b class='flag-5'>狀態(tài)設(shè)計(jì)模式,通過C++的繼承特性,以及類指針,實(shí)現(xiàn)炸彈拆除小游戲中的狀態(tài)機(jī)功能。
    的頭像 發(fā)表于 06-28 09:04 ?2078次閱讀
    <b class='flag-5'>狀態(tài)機(jī)</b><b class='flag-5'>編程</b>實(shí)例-面向?qū)ο蟮?b class='flag-5'>狀態(tài)</b>設(shè)計(jì)模式

    raw os 之狀態(tài)機(jī)編程

    狀態(tài)機(jī)編程的歷史很可能久于傳統(tǒng)的操作系統(tǒng), 傳統(tǒng)的一個大while 循環(huán)模式普遍用到了狀態(tài)機(jī)模式編程, 狀態(tài)機(jī)一般是基于fsm 的有限
    發(fā)表于 02-27 14:35

    什么是狀態(tài)機(jī)狀態(tài)機(jī)是如何編程的?

    什么是狀態(tài)機(jī)?狀態(tài)機(jī)是如何編程的?
    發(fā)表于 10-20 07:43

    什么是狀態(tài)機(jī)?狀態(tài)機(jī)的三種實(shí)現(xiàn)方法

    文章目錄1、什么是狀態(tài)機(jī)?2、狀態(tài)機(jī)編程優(yōu)點(diǎn)(1)提高CPU使用效率(2) 邏輯完備性(3)程序結(jié)構(gòu)清晰3、狀態(tài)機(jī)的三種實(shí)現(xiàn)方法switc
    發(fā)表于 12-22 06:51

    狀態(tài)機(jī)原理及用法

    狀態(tài)機(jī)原理及用法狀態(tài)機(jī)原理及用法狀態(tài)機(jī)原理及用法
    發(fā)表于 03-15 15:25 ?0次下載

    狀態(tài)機(jī)概述 如何理解狀態(tài)機(jī)

    本篇文章包括狀態(tài)機(jī)的基本概述以及通過簡單的實(shí)例理解狀態(tài)機(jī)
    的頭像 發(fā)表于 01-02 18:03 ?1.1w次閱讀
    <b class='flag-5'>狀態(tài)機(jī)</b>概述  如何理解<b class='flag-5'>狀態(tài)機(jī)</b>

    FPGA:狀態(tài)機(jī)簡述

    本文目錄 前言 狀態(tài)機(jī)簡介 狀態(tài)機(jī)分類 Mealy 型狀態(tài)機(jī) Moore 型狀態(tài)機(jī) 狀態(tài)機(jī)描述 一段式
    的頭像 發(fā)表于 11-05 17:58 ?8027次閱讀
    FPGA:<b class='flag-5'>狀態(tài)機(jī)</b>簡述

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

    本文總結(jié)下狀態(tài)機(jī)編程優(yōu)點(diǎn)。 提高CPU使用效率 話說我只要見到滿篇都是delay_ms()的程序就會頭疼,動輒十幾個ms幾十個ms的軟件延時是對CPU資源的巨大浪費(fèi),寶貴的CPU時間都浪費(fèi)在了
    的頭像 發(fā)表于 07-27 11:05 ?5972次閱讀

    什么是狀態(tài)機(jī)?狀態(tài)機(jī)5要素

    玩單片機(jī)還可以,各個外設(shè)也都會驅(qū)動,但是如果讓你完整的寫一套代碼時,卻無邏輯與框架可言。這說明編程還處于比較低的水平,你需要學(xué)會一種好的編程框架或者一種編程思想!比如模塊化
    的頭像 發(fā)表于 07-27 11:23 ?2.1w次閱讀
    什么是<b class='flag-5'>狀態(tài)機(jī)</b>?<b class='flag-5'>狀態(tài)機(jī)</b>5要素

    MCU裸機(jī)編程狀態(tài)機(jī)框架--第一部分

    MCU裸機(jī)編程狀態(tài)機(jī)框架--第一部分1 狀態(tài)機(jī)的概念1.1 狀態(tài)機(jī)的要素1.2 狀態(tài)遷移表1.3 狀態(tài)
    發(fā)表于 12-09 13:21 ?17次下載
    MCU裸機(jī)<b class='flag-5'>編程</b>的<b class='flag-5'>狀態(tài)機(jī)</b>框架--第一部分

    單片機(jī)編程技巧—狀態(tài)機(jī)編程

    學(xué)會一種好的編程框架或者一種編程思想,可能會受用終生!比如模塊化編程,框架式編程,狀態(tài)機(jī)編程等等
    發(fā)表于 02-08 16:08 ?12次下載
    單片<b class='flag-5'>機(jī)</b><b class='flag-5'>編程</b>技巧—<b class='flag-5'>狀態(tài)機(jī)</b><b class='flag-5'>編程</b>

    嵌入式狀態(tài)機(jī)編程優(yōu)點(diǎn)分析

    嵌入式中狀態(tài)機(jī)編程是真的好用,寫出來的程序結(jié)構(gòu)非常清晰!所以平時用的也比較多。
    的頭像 發(fā)表于 02-25 16:21 ?1064次閱讀

    什么是狀態(tài)機(jī)?狀態(tài)機(jī)的種類與實(shí)現(xiàn)

    狀態(tài)機(jī),又稱有限狀態(tài)機(jī)(Finite State Machine,F(xiàn)SM)或米利狀態(tài)機(jī)(Mealy Machine),是一種描述系統(tǒng)狀態(tài)變化的模型。在芯片設(shè)計(jì)中,
    的頭像 發(fā)表于 10-19 10:27 ?1.2w次閱讀