電子產(chǎn)業(yè)一站式賦能平臺(tái)

PCB聯(lián)盟網(wǎng)

搜索
查看: 11|回復(fù): 0
收起左側(cè)

嵌入式軟件使用狀態(tài)機(jī)架構(gòu),一般有什么優(yōu)點(diǎn)?

[復(fù)制鏈接]

485

主題

485

帖子

1623

積分

三級(jí)會(huì)員

Rank: 3Rank: 3

積分
1623
跳轉(zhuǎn)到指定樓層
樓主
我是老溫,一名熱愛(ài)學(xué)習(xí)的嵌入式工程師* i3 j8 v% w6 z# i7 O" \! J
關(guān)注我,一起變得更加優(yōu)秀!' \  y! S& {7 Y" w8 b. Y9 m
本文總結(jié)下?tīng)顟B(tài)機(jī)編程的優(yōu)點(diǎn)。: T' ?$ A/ |* P) z" c% s6 N" j9 Q
一、提高CPU使用效率# x2 V* D1 X" c, ^6 y
話說(shuō)我只要見(jiàn)到滿篇都是delay_ms()的程序就會(huì)頭疼,動(dòng)輒十幾個(gè)ms幾十個(gè)ms的軟件延時(shí)是對(duì)CPU資源的巨大浪費(fèi),寶貴的CPU時(shí)間都浪費(fèi)在了NOP指令上。0 g- z9 Y+ N: C3 j9 Z
那種為了等待一個(gè)管腳電平跳變或者一個(gè)串口數(shù)據(jù),讓整個(gè)程序都不動(dòng)的情況也讓我非常糾結(jié),如果事件一直不發(fā)生電平跳變,你要等到世界末日么?/ I& t2 V, ~- V
如果應(yīng)用狀態(tài)機(jī)編程思想,程序只需要用全局變量記錄下工作狀態(tài),就可以轉(zhuǎn)頭去干別的工作了,當(dāng)然忙完那些活兒之后要再看看工作狀態(tài)有沒(méi)有變化。
6 \4 `# {* L& M& U5 h/ a" S% e只要目標(biāo)事件(定時(shí)未到、電平?jīng)]跳變、串口數(shù)據(jù)沒(méi)收完)還沒(méi)發(fā)生,工作狀態(tài)就不會(huì)改變,程序就一直重復(fù)著“查詢—干別的—查詢—干別的”這樣的循環(huán),這樣CPU就閑不下來(lái)了。
; u$ C, F6 U8 r5 h+ b- D5 C這種處理方法的實(shí)質(zhì)就是在程序等待事件的過(guò)程中間隔性地插入一些有意義的工作,好讓CPU不是一直無(wú)謂地等待。, `% C! n5 P% U& @! f$ J: C3 L2 C

4 G7 d: X8 S9 \! l二、邏輯完備性+ ~& e/ U2 h  [( o3 o
邏輯完備性是狀態(tài)機(jī)編程最大的優(yōu)點(diǎn)。9 h! X' }! L% o6 Y6 g) X
不知道大家有沒(méi)有用C語(yǔ)言寫(xiě)過(guò)計(jì)算器的小程序,我很早以前寫(xiě)過(guò),寫(xiě)出來(lái)一測(cè)試,那個(gè)慘不忍睹啊!
; F/ f1 ~8 ^) N$ ]' ?  D7 T當(dāng)我規(guī)規(guī)矩矩的輸入算式的時(shí)候,程序可以得到正確的計(jì)算結(jié)果,但要是故意輸入數(shù)字和運(yùn)算符號(hào)的隨意組合,程序總是得出莫名其妙的結(jié)果。" G5 O% C; Z, g2 f
后來(lái)我試著思維模擬一下程序的工作過(guò)程,正確的算式思路清晰,流程順暢,可要碰上了不規(guī)矩的式子,走著走著我就暈菜了,那么多的標(biāo)志位,那么多的變量,變來(lái)變?nèi),最后直接分析不下去了?br /> " w" R5 A+ Z- I$ ?. u很久之后我認(rèn)識(shí)了狀態(tài)機(jī),才恍然明白,當(dāng)時(shí)的程序是有邏輯漏洞的。
9 _( a. [5 ~  j8 J2 l& b如果把這個(gè)計(jì)算器程序當(dāng)做是一個(gè)反應(yīng)式系統(tǒng),那么一個(gè)數(shù)字或者運(yùn)算符就可以看做一個(gè)事件,一個(gè)算式就是一組事件組合。
  [) F$ K7 C2 Y對(duì)于一個(gè)邏輯完備的反應(yīng)式系統(tǒng),不管什么樣的事件組合,系統(tǒng)都能正確處理事件,而且系統(tǒng)自身的工作狀態(tài)也一直處在可知可控的狀態(tài)中。, \$ I! V$ V  @: D/ Q8 F6 h6 N/ Q+ g1 i
反過(guò)來(lái),如果一個(gè)系統(tǒng)的邏輯功能不完備,在某些特定事件組合的驅(qū)動(dòng)下,系統(tǒng)就會(huì)進(jìn)入一個(gè)不可知不可控的狀態(tài),與設(shè)計(jì)者的意圖相悖。
4 ?8 m: a/ @+ K9 |狀態(tài)機(jī)就能解決邏輯完備性的問(wèn)題。. w- n- K7 J, v3 d& x
狀態(tài)機(jī)是一種以系統(tǒng)狀態(tài)為中心,以事件為變量的設(shè)計(jì)方法,它專注于各個(gè)狀態(tài)的特點(diǎn)以及狀態(tài)之間相互轉(zhuǎn)換的關(guān)系。7 ?, H* x! T2 y7 q. O: H" R
狀態(tài)的轉(zhuǎn)換恰恰是事件引起的,那么在研究某個(gè)具體狀態(tài)的時(shí)候,我們自然而然地會(huì)考慮任何一個(gè)事件對(duì)這個(gè)狀態(tài)有什么樣的影響。( h+ z0 H- ^9 A& G
這樣,每一個(gè)狀態(tài)中發(fā)生的每一個(gè)事件都會(huì)在我們的考慮之中,也就不會(huì)留下邏輯漏洞。$ [5 k7 j: L+ B+ K+ y6 ^3 y0 ~
這樣說(shuō)也許大家會(huì)覺(jué)得太空洞,實(shí)踐出真知,某天如果你真的要設(shè)計(jì)一個(gè)邏輯復(fù)雜的程序,會(huì)覺(jué)得狀態(tài)機(jī)真香!
6 |# }) E! T& O/ A/ m+ H( m三、程序結(jié)構(gòu)清晰3 U4 E) W2 I0 L! Y2 `
用狀態(tài)機(jī)寫(xiě)出來(lái)的程序的結(jié)構(gòu)是非常清晰的。
# o9 v/ t' ^" |) n6 b: X程序員最痛苦的事兒莫過(guò)于讀別人寫(xiě)的代碼,如果代碼不是很規(guī)范,而且手里還沒(méi)有流程圖,讀代碼會(huì)讓人暈了又暈,只有順著程序一遍又一遍的看,很多遍之后才能隱約地明白程序大體的工作過(guò)程。0 ^: h7 G  s& u$ w5 ~2 x
有流程圖會(huì)好一點(diǎn),但是如果程序比較大,流程圖也不會(huì)畫(huà)得多詳細(xì),很多細(xì)節(jié)上的過(guò)程還是要從代碼中理解。
" P' W& p* Y& N* v3 u相比之下,用狀態(tài)機(jī)寫(xiě)的程序要好很多,拿一張標(biāo)準(zhǔn)的UML狀態(tài)轉(zhuǎn)換圖,再配上一些簡(jiǎn)明的文字說(shuō)明,程序中的各個(gè)要素一覽無(wú)余。
6 k& T1 C8 h8 C+ h* D9 U+ l程序中有哪些狀態(tài),會(huì)發(fā)生哪些事件,狀態(tài)機(jī)如何響應(yīng),響應(yīng)之后跳轉(zhuǎn)到哪個(gè)狀態(tài),這些都十分明朗,甚至許多動(dòng)作細(xì)節(jié)都能從狀態(tài)轉(zhuǎn)換圖中找到。- \# @4 r4 \, X1 P, [. R" @
可以毫不夸張的說(shuō),有了UML狀態(tài)轉(zhuǎn)換圖,程序流程圖寫(xiě)都不用寫(xiě)。
% c6 E& W: [. X$ A. Y8 {, v# {2 h8 T文章來(lái)源:牛逼的工程師網(wǎng)友$ \+ y6 y5 L# l8 a; e

9 z4 ]5 q9 p  {0 t7 ^- z-END-1 u" Z- h: y, Y0 P4 X
往期推薦:點(diǎn)擊圖片即可跳轉(zhuǎn)閱讀' N! `1 o1 t* G
                                                       
8 n3 H6 Y& g5 I1 O9 ?# l! A                                                                ) k0 y; G9 h/ g2 @) s
                                                                       
$ p' _" Q3 n; g' D* I- ]4 |                                                                               
1 `: H2 p9 W9 D( ]6 M. ]6 d0 Y) |5 g 6 R  z( T7 [& a& _5 B5 _
                                                                                * o/ F: R+ B: T0 A4 v0 N
                                                                                        嵌入式編程,一些常見(jiàn)的計(jì)算機(jī)術(shù)語(yǔ)。' s% E6 c! e1 @3 |
                                                        3 Q& C! N+ j9 ], F' ]
                                                                / `: Y4 f2 u  t7 [# ?& k) t9 v3 p
                                                                       
2 L" s$ M0 H* j& \8 R# P- B                                                                                / P$ K; D" i. p( U. L/ v

% R" s4 k9 T8 H6 K) V* U2 y- F# n# T                                                                               
" f7 j  E# c( C* w, E3 P! T                                                                                        他們說(shuō),這是史上最強(qiáng)的STM32單片機(jī),并且不接受反駁!
2 z/ p# P1 q& D  S! v                                                                # p4 N2 H6 c0 ?
                                                                       
/ o( Y* g# r+ o: ^7 [3 r: m                                                                                * X8 G5 I2 V$ @7 x
( _; w6 i4 r* Y8 a" O
                                                                                / G5 h0 E  D# b) G: t3 V
                                                                                        設(shè)計(jì)一個(gè)嵌入式設(shè)備日志記錄模塊+ X' f- W% T! e7 @8 L8 J
                                                                               
$ |# n7 n- _3 M9 i. C. n" O                                                                       
; Q$ s8 L) l( f* n                                                                8 k  h" |$ n% l% C
                                                        我是老溫,一名熱愛(ài)學(xué)習(xí)的嵌入式工程師
' u, |/ ^3 k5 `/ B# I關(guān)注我,一起變得更加優(yōu)秀!

發(fā)表回復(fù)

本版積分規(guī)則


聯(lián)系客服 關(guān)注微信 下載APP 返回頂部 返回列表