2016-2022 All Rights Reserved.平安財(cái)經(jīng)網(wǎng).復(fù)制必究 聯(lián)系QQ 備案號(hào):
本站除標(biāo)明“本站原創(chuàng)”外所有信息均轉(zhuǎn)載自互聯(lián)網(wǎng) 版權(quán)歸原作者所有。
郵箱:toplearningteam#gmail.com (請(qǐng)將#換成@)
軟件庫,供應(yīng)商或團(tuán)隊(duì)聲稱他們開發(fā)高質(zhì)量的軟件并不罕見。這個(gè)宣言的問題在于,不同的開發(fā)人員和團(tuán)隊(duì)之間的質(zhì)量定義可以有很大的不同。一個(gè)團(tuán)隊(duì)可能會(huì)認(rèn)為任何符合MISRA-C的代碼庫都是高質(zhì)量的代碼庫,而另一個(gè)團(tuán)隊(duì)可能只關(guān)心每個(gè)函數(shù)的圈復(fù)雜度為10或更低。其他人可能只是運(yùn)行一些測試用例并聲稱他們的軟件沒有錯(cuò)誤,因此也是高質(zhì)量的軟件。由于每個(gè)人都有自己的質(zhì)量定義,因此團(tuán)隊(duì)必須以一種既不是文件記錄也可以衡量的方式來定義質(zhì)量。在這篇文章中,我們將探討幾個(gè)可用于定義軟件質(zhì)量的可衡量的軟件度量標(biāo)準(zhǔn)。
嵌入式系統(tǒng)行業(yè)充滿了標(biāo)準(zhǔn),旨在幫助開發(fā)人員避免擺在他們面前的開發(fā)人員的陷阱和痛苦。這些標(biāo)準(zhǔn)的重點(diǎn)可能略有不同,從簡單的風(fēng)格標(biāo)準(zhǔn)到MISRA-C等標(biāo)準(zhǔn),為開發(fā)人員提供了C語言的子集。按照規(guī)定的標(biāo)準(zhǔn)開發(fā)軟件可以避免常見的陷阱。最終,它提升了軟件的質(zhì)量。
成千上萬的新英格蘭工程師和擁有購買力的高管將來到新英格蘭設(shè)計(jì)與制造公司,這是該地區(qū)最先進(jìn)的制造業(yè)展覽會(huì)。他們的第一目標(biāo):尋找供應(yīng)商。為了吸引他們,數(shù)百家公司將參加展會(huì)。如果您現(xiàn)在預(yù)訂展位,可以加入他們。
在驗(yàn)證編碼標(biāo)準(zhǔn)時(shí),通常有兩個(gè)必需的組件:自動(dòng)工具分析和代碼審查。例如,MISRA-C是開發(fā)人員遵循的一種非常常見的編碼標(biāo)準(zhǔn)。靜態(tài)代碼分析器可用于驗(yàn)證標(biāo)準(zhǔn)中90%的指令,但有些指令無法通過工具進(jìn)行驗(yàn)證。為了確保滿足標(biāo)準(zhǔn),開發(fā)人員需要定期執(zhí)行代碼審查并手動(dòng)檢查剩余的指令。滿足標(biāo)準(zhǔn)可以是確保在軟件中滿足最低質(zhì)量水平的好方法。
我認(rèn)為每個(gè)開發(fā)團(tuán)隊(duì)?wèi)?yīng)該監(jiān)控并添加其質(zhì)量定義的我最喜歡的質(zhì)量測量之一是McCabe Cyclomatic Complexity測量。這是一個(gè)簡單的測量,可以在任何確定通過函數(shù)的路徑數(shù)的函數(shù)上執(zhí)行。值為10或更小的函數(shù)被認(rèn)為是易于測試和維護(hù)的簡單函數(shù)。盡管如此,測試所需的路徑數(shù)量開始變得更加復(fù)雜,困難,并且易于開發(fā)和維護(hù),這可以用來表明代碼質(zhì)量較低。事實(shí)上,當(dāng)復(fù)雜度數(shù)接近大于20的數(shù)字時(shí),幾乎不可能正確地測試函數(shù)。如果無法正確測試功能,如何顯示其正常工作?
測量復(fù)雜性也可以是自動(dòng)化過程。有免費(fèi)的工具,如CCCC和Eclipse測量儀插件,可用于測量圈復(fù)雜度。還有IDE,例如Understanding,可用于收集有關(guān)代碼庫的度量信息。成功測量該指標(biāo)的關(guān)鍵是:首先,決定進(jìn)行測量;第二,在將新代碼檢入代碼庫之前執(zhí)行測量。它也應(yīng)該在持續(xù)集成服務(wù)器上執(zhí)行。
我遇到的軟件庫和代碼庫太多,沒有警告就不能編譯。警告是編譯器告訴開發(fā)人員他們正在做一些看起來不太正確的事情的方法。鑒于大多數(shù)編譯器都會(huì)讓開發(fā)人員在代碼中做一些可怕的事情,編譯器通過警告調(diào)用開發(fā)人員的事實(shí)意味著開發(fā)人員應(yīng)該注意!在沒有單一警告的情況下編譯的代碼是一種易于衡量的指標(biāo),表明軟件滿足其他軟件可能無法滿足的質(zhì)量水平。它仍然可能存在錯(cuò)誤或其他質(zhì)量問題,但至少代碼本身在語義上是正確的。
我認(rèn)為,我在行業(yè)開發(fā)周期中看到的最大缺陷之一是開發(fā)能夠獲得100%代碼覆蓋率的測試。實(shí)際上,問題不在于100%的代碼覆蓋率;它只是了解測試實(shí)際覆蓋的代碼量!如果團(tuán)隊(duì)知道他們的測試用例覆蓋了85%的軟件,那將是一回事。然而,大多數(shù)團(tuán)隊(duì)甚至都不知道。代碼覆蓋率可以是跟蹤顯示軟件質(zhì)量水平的重要指標(biāo)。顯然,已經(jīng)測試到85%的東西將比僅測試到50%的東西更強(qiáng)大和更高的質(zhì)量。開發(fā)人員可以測量此值并將其用作代碼質(zhì)量的內(nèi)部指標(biāo)。我們將在以后的文章中介紹如何執(zhí)行此操作。
代碼驗(yàn)證與測試覆蓋類似,不同之處在于我們不是測量覆蓋了多少代碼,而是測量實(shí)際通過或失敗的測試百分比。例如,我們可以根據(jù)以下因素生成數(shù)值:
使用這些指標(biāo),我們可以根據(jù)測試執(zhí)行的成功程度生成0到10范圍內(nèi)的數(shù)值。然后,這為我們提供了一個(gè)評(píng)估指標(biāo),如果我們沒有達(dá)到所需的代碼驗(yàn)證級(jí)別,我們可以返回并改進(jìn)測試過程,直到我們達(dá)到所需的級(jí)別,這也對(duì)應(yīng)于所需的代碼質(zhì)量級(jí)別。
為了獲得高質(zhì)量的軟件,開發(fā)團(tuán)隊(duì)需要定義“質(zhì)量”一詞。該定義應(yīng)包括可在整個(gè)開發(fā)過程中輕松跟蹤和監(jiān)控的可衡量指標(biāo)。在本文中,我們探討了一些高級(jí)定義,這些定義應(yīng)該是為了創(chuàng)建高質(zhì)量代碼庫而遵循的最小度量和過程。實(shí)施這些指標(biāo)不僅可以幫助您提升一般代碼質(zhì)量,還可以消除和防止軟件缺陷。
Jacob Beningo是一名嵌入式軟件顧問,目前與十幾個(gè)國家的客戶合作,通過提高產(chǎn)品質(zhì)量,成本和上市時(shí)間來大幅改變他們的業(yè)務(wù)。他發(fā)表了200多篇關(guān)于嵌入式軟件開發(fā)技術(shù)的文章,是一位廣受歡迎的演講者和技術(shù)培訓(xùn)師,擁有三個(gè)學(xué)位,其中包括密歇根大學(xué)的工程碩士學(xué)位。請(qǐng)隨時(shí)通過jacob@beningo.com或他的網(wǎng)站與他聯(lián)系。另外,請(qǐng)注冊(cè)他的每月Embedded Bytes時(shí)事通訊。
2016-2022 All Rights Reserved.平安財(cái)經(jīng)網(wǎng).復(fù)制必究 聯(lián)系QQ 備案號(hào):
本站除標(biāo)明“本站原創(chuàng)”外所有信息均轉(zhuǎn)載自互聯(lián)網(wǎng) 版權(quán)歸原作者所有。
郵箱:toplearningteam#gmail.com (請(qǐng)將#換成@)