利用函數(shù)參數(shù)和返回值提高嵌入式軟件質(zhì)量
3 狀態(tài)信息的使用
在調(diào)用μC/OS―II的每個系統(tǒng)函數(shù)時,只要被調(diào)用的函數(shù)提供狀態(tài)信息,都應該對這些狀態(tài)信息進行分析和處理。專業(yè)軟件設(shè)計者信奉這樣一個道理:“編寫無錯代碼的最好方法是把防止錯誤放在第一位”。以調(diào)用μC/OS―II的系統(tǒng)函數(shù)OSSemPend()為例,用戶不需要去改動OSSemPend()函數(shù)的代碼,假設(shè)這部分內(nèi)容是沒有什么問題的?,F(xiàn)在我們要做的是檢測這個函數(shù)執(zhí)行時的狀態(tài),也就是它產(chǎn)生的出錯信息。這個函數(shù)返回三種結(jié)果說明用戶使用的錯誤,如表1所列:0S_ERR_EVENT_TYPE表示用戶在調(diào)用OSSemPend()函數(shù)時提供的指針數(shù)據(jù)不是指向信號量的,發(fā)生了類型錯誤;OS_ERR_PEVENT_NULL表示用戶提供的用作實際參數(shù)的指針是一個空指針;OS_ERR_PEND_ISR表示用戶在中斷服務(wù)程序中調(diào)用了OSSemPend()函數(shù);這三種狀態(tài)錯誤是在軟件設(shè)計階段由于用戶粗心或者對μC/OS―II系統(tǒng)函數(shù)不了解而導致的。只要用戶在設(shè)計過程中小心謹慎,這類錯誤可以避免。但是,從防止錯誤的角度來考慮,對這些錯誤的狀態(tài)進行檢測和處理是必要的,這樣在錯誤發(fā)生時錯誤處理程序會給出簡單的提示甚至對錯誤進行修改。錯誤處理程序防止在程序調(diào)試過程中反復閱讀程序代碼,避免了花費很大的精力去查找錯誤,提高了軟件設(shè)計效率。
按照以上方案設(shè)計出的嵌入式系統(tǒng)軟件可以認為是一個理想的編譯器?,F(xiàn)在考慮一下,倘若編譯程序能夠正確地指出代碼中的所有問題,那相應程序的錯誤情況會怎樣?這不單指語法錯誤,還包括程序中的任何問題,不管它多么隱蔽。顯然,現(xiàn)在所有的編譯器都無法實現(xiàn)這種功能,所以要對編譯器的功能進行擴展。這種設(shè)計思路可以認為是:軟件設(shè)計者要設(shè)計出編譯器的擴展功能,使得在進行軟件設(shè)計時,編譯器能夠自己檢查錯誤。如果能夠做到,軟件設(shè)計的勞動量將大大降低。
4 軟件的調(diào)試版與交付版
前面的改進程序?qū)SSemPend()函數(shù)調(diào)用產(chǎn)生的所有可能狀態(tài)進行了處理,而這部分代碼中的大部分都是冗余代碼,為的是便于軟件的設(shè)計和調(diào)試。使用實時操作系統(tǒng)μC/0S―II進行嵌入式軟件設(shè)計,用到的系統(tǒng)函數(shù)當然不止OSSemPend()一個,如果每個函數(shù)調(diào)用結(jié)束后都像程序中那樣處理,代碼的空間會迅速增加,程序的效率則會大大降低。
為了解決這個問題,首先考慮,如果非常謹慎小心進行程序設(shè)計,多數(shù)的狀態(tài)檢測處理過程就可以省略。之所以對每個狀態(tài)信息進行檢測處理是為了提高軟件設(shè)計調(diào)試的效率。在軟件調(diào)試通過后,有些狀態(tài)信息的檢測就沒有必要了。這就像乘坐飛機出行前要買保險,等航班到達目的地后,保險就沒有什么用處了。軟件最終是作為一個產(chǎn)品提供給客戶的。這個產(chǎn)品是最終版本(當然還會不斷升級)。在進行產(chǎn)品設(shè)計時會有一個調(diào)試版本,這個調(diào)試版要貫穿整個軟件的生存周期。調(diào)試版是為了軟件的設(shè)計、調(diào)試和升級使用,不會提供給用戶,更不會出現(xiàn)在產(chǎn)品中。
具體到嵌入式系統(tǒng)軟件設(shè)計問題,仍然以調(diào)用OS―SemPend()函數(shù)的代碼為例來說明問題。調(diào)用OSSem―
通過觀察上述程序和前面的改進發(fā)現(xiàn),本段程序中加了幾個條件編譯指令。如果沒有定義TEST標志,則有一部分代碼將不會被編譯,這就是交付版軟件。反之,如果定義了TEST標志,則表示為調(diào)試版,所有的指令代碼都會被編譯。通過比較這兩個版本看到:交付版的代碼比調(diào)試版的代碼在數(shù)量上大大減少。而且通過分析知道,在軟件調(diào)試通過以后,就不存在OS_ERR_EVENT_TYPE、0S_ERR_PEND_ISR和OS_ERR_PEVENT_NULL的錯誤了,這兩個版本實現(xiàn)的功能完全相同,這部分代碼確實沒有編譯的必要了。
結(jié) 語
嵌入式系統(tǒng)軟件設(shè)計過程中,大部分場合會用到嵌入式實時操作系統(tǒng)。用戶在保證自已設(shè)計代碼質(zhì)量的前提下,還要充分考慮調(diào)用系統(tǒng)函數(shù)時產(chǎn)生的狀態(tài)信息,并進行適當?shù)奶幚怼V挥羞@樣,才能夠提高軟件的設(shè)計效率,縮短設(shè)計周期。
評論