|
學(xué)嵌入式開發(fā)用什么_關(guān)于硬件工程師之路上的8個(gè)軟件分析和發(fā)展之路,
嵌入式系統(tǒng)設(shè)計(jì)不僅要了解硬件還應(yīng)該了解它與軟件之間的相互影響和作用。硬件設(shè)計(jì)需要一定的設(shè)計(jì)范例,這點(diǎn)對于軟件設(shè)計(jì)卻不那么適用。如何從單純的硬件設(shè)計(jì)過渡到硬軟結(jié)合的設(shè)計(jì),在你著手開發(fā)軟件時(shí)需注意以下八個(gè)軟件設(shè)計(jì)技巧。
1、設(shè)計(jì)控制流程圖
工程師進(jìn)行到開發(fā)軟件這一步時(shí)會情不自禁地開始書寫代碼。這種思維定勢就像在原理圖還未完成之前就開始嘗試畫PCB。當(dāng)著手開發(fā)軟件時(shí),克制寫代碼的沖動,取而代之的應(yīng)該是軟件流程結(jié)構(gòu)圖表的設(shè)計(jì),這點(diǎn)非常重要。
流程圖能清晰地呈現(xiàn)給開發(fā)人員軟件的各個(gè)需要的組成部件,正如電路圖列出硬件設(shè)計(jì)所需的各種元器件一樣。做到這點(diǎn)能很大程度上使程序整體更易于組織,而且也會減少占開發(fā)周期較長的調(diào)試工作量進(jìn)而節(jié)省時(shí)間減少調(diào)試的繁瑣。
2、使用狀態(tài)機(jī)控制程序流程
狀態(tài)機(jī)是20世紀(jì)優(yōu)秀的軟件發(fā)明之一。應(yīng)用程序一般被分解為多個(gè)不同的狀態(tài),每一個(gè)狀態(tài)控制一個(gè)特定的程序分支。狀態(tài)機(jī)包括內(nèi)部狀態(tài)和依據(jù)不同激勵(lì)所控制的狀態(tài)轉(zhuǎn)換。使用狀態(tài)機(jī)機(jī)制設(shè)計(jì)軟件能夠使模塊化的可維護(hù)的軟件開發(fā)更加容易而且易于理解。狀態(tài)機(jī)原理與算法的示例隨處可見。
3、避免使用全局變量
在過去的函數(shù)式編程中,程序員使用函數(shù)編寫程序,他們的唯一目標(biāo)是使程序盡可能快的運(yùn)行而不考慮程序的結(jié)構(gòu)和重用性。這類程序風(fēng)格在使用全局變量時(shí)不注意變量的作用范圍引起其他函數(shù)修改的危險(xiǎn)性。這樣變量會被多次占用和重寫。如今面向?qū)ο蟮某绦蛟O(shè)計(jì)中,成員變量被定義在最小的作用范圍之內(nèi)并封裝起來避免被重新復(fù)值和濫用。所以建議盡量少地使用全局變量,實(shí)在需要的話,使用C語言中的關(guān)鍵字“extern”來修飾。
4、充分利用模塊化的設(shè)計(jì)理念
如果你問一位工程師項(xiàng)目的哪一部分最有可能會拖延交付并超出預(yù)估時(shí)間,那答案一定是軟件周期了。軟件通常是復(fù)雜而且不易開發(fā)和維護(hù)的,特別是當(dāng)項(xiàng)目應(yīng)用程序集中在一個(gè)單一的文件里,或者幾個(gè)結(jié)構(gòu)松散的文件中時(shí)。
為了便于代碼重用和軟件可維護(hù)并減小軟件的復(fù)雜度,強(qiáng)烈建議發(fā)揮高級程序設(shè)計(jì)語言模塊化的特性,在程序的結(jié)構(gòu)中把公用的函數(shù)分離出來作為一個(gè)獨(dú)立的模塊。通過這種方式可以讓程序員開始創(chuàng)建包含有常用函數(shù)和常用的聲明定義,它可以很容易的被其他的代碼重用,這在以后的測試階段不僅可以節(jié)省時(shí)間代價(jià)還能提高代碼的質(zhì)量。
5、中斷服務(wù)事件保持簡練
中斷服務(wù)事件是中斷處理器正在執(zhí)行的程序,轉(zhuǎn)而去處理觸發(fā)該中斷的外設(shè)的請求的一種機(jī)制。處理器響應(yīng)中斷請求需要大量的系統(tǒng)開銷,具體表現(xiàn)在保存被中斷程序的狀態(tài)(入棧下條指令的段地址、偏移地址和程序狀態(tài)寄存器,有時(shí)還會入棧若干寄存器的值),執(zhí)行中斷服務(wù)程序然后恢復(fù)中斷點(diǎn)繼續(xù)執(zhí)行(依次出棧各寄存器),雖然現(xiàn)在的處理器速度非常快但是這種系統(tǒng)開銷仍然需要考慮。一般來說,為了避免與主程序沖突程序員總想使中斷執(zhí)行時(shí)間減小到最小。這就意味著中斷服務(wù)事件應(yīng)該短小簡單。不能在中斷程序中調(diào)用函數(shù)。另外,如果中斷需要處理的事件特別復(fù)雜或者需要花費(fèi)較長的時(shí)間,這個(gè)時(shí)候中斷服務(wù)程序應(yīng)該滿足最小的需求,例如將數(shù)據(jù)載入到緩沖寄存器、設(shè)置標(biāo)志位,而讓主程序去處理讀入的數(shù)據(jù)。這樣處理器的工作大部分周期都在處理程序而不是中斷。
6、使用處理器示例代碼測試設(shè)備
對于硬件設(shè)計(jì),在畫板之前標(biāo)準(zhǔn)的測試電路有助于工程師理解電路的特性。同樣可以適用于軟件設(shè)計(jì),半導(dǎo)體廠商通常有測試微處理器各個(gè)部分的功能的示例程序提供工程師體驗(yàn)各部分是如何工作的。據(jù)此可以提前組織軟件的結(jié)構(gòu)并且預(yù)知在設(shè)計(jì)中的問題。提前確定在設(shè)計(jì)潛在的障礙遠(yuǎn)比在產(chǎn)品完成前幾個(gè)小時(shí)發(fā)現(xiàn)問題更加科學(xué)合理。而值得注意的是廠商提供的代碼通常不是模塊化而且不做必要的修改是很難直接用于實(shí)際的軟件中的。
7、控制函數(shù)的復(fù)雜度
在工程設(shè)計(jì)中有句俗語叫“KISS”,意思是“Keep It Simple Silly”。在處理一些復(fù)雜的任務(wù)時(shí)最簡單有效的方法是把它分解成若干個(gè)簡單的子任務(wù),當(dāng)任務(wù)或者功能很復(fù)雜時(shí),人們很難留意所有的細(xì)節(jié)也很難不出錯(cuò)。當(dāng)工程師寫了一個(gè)在當(dāng)時(shí)能夠理解的復(fù)雜函數(shù),可一段時(shí)間后需要維護(hù)程序了還能不能清晰的呈現(xiàn)出當(dāng)初的設(shè)計(jì)思想這是值得考慮的。有大量的技術(shù)來衡量函數(shù)的復(fù)雜度像“循環(huán)復(fù)雜度”。經(jīng)驗(yàn)告訴我們,函數(shù)的循環(huán)復(fù)雜度應(yīng)該低于10比較好。
8、詳細(xì)的文檔
在激烈的軟件開發(fā)競爭中關(guān)注的焦點(diǎn)很容易就局限在代碼的書寫和調(diào)試而忽略文檔的編寫。有時(shí)迫于壓力要求寫文檔,開發(fā)人員通常把文檔安排在項(xiàng)目開發(fā)的最后的一個(gè)環(huán)節(jié)集中編寫。然而給代碼寫文檔應(yīng)該乘在頭腦里面還比較清晰的時(shí)候比較關(guān)鍵,這樣在后續(xù)的開發(fā)或者自己閱讀注釋的時(shí)候能很快的回憶起當(dāng)時(shí)的設(shè)計(jì)思想。 |
|