0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

在尋求無錯誤軟件的過程中增強靜態(tài)代碼分析

星星科技指導員 ? 來源:嵌入式計算設計 ? 作者:Rutul Dave ? 2022-06-28 15:58 ? 次閱讀

嵌入式軟件無處不在,并在各種設備中提供關(guān)鍵功能,從最新智能手機和游戲小工具到救生醫(yī)療設備。創(chuàng)建嵌入式軟件的工程組織明白,確保代碼質(zhì)量是一個關(guān)鍵的差異化因素和競爭優(yōu)勢。與其他測試和驗證方法一起,許多公司利用代碼測試和現(xiàn)代靜態(tài)分析的優(yōu)勢在開發(fā)早期識別缺陷。在過去幾年中,嵌入式市場研究公司 VDC Research 的各種報告表明,采用靜態(tài)分析作為關(guān)鍵測試自動化工具的公司增長強勁?,F(xiàn)代靜態(tài)分析可以說是應對確保復雜軟件質(zhì)量挑戰(zhàn)的最具成本效益、自動化和可重復的方法。

推動這種增長的一個重要原因是,用于識別關(guān)鍵缺陷(如內(nèi)存損壞、資源泄漏、空指針取消引用和無效內(nèi)存訪問)的技術(shù)已經(jīng)成熟到可以發(fā)現(xiàn)大量難以發(fā)現(xiàn)的遍歷函數(shù)的缺陷的程度現(xiàn)在可以準確地完成文件邊界,從而導致非常少的誤報。然而,真正的創(chuàng)新在于為每個已識別的缺陷提供上下文信息。開發(fā)人員需要知道缺陷存在的原因、會產(chǎn)生什么影響以及需要修復的地方。

需要修復的問題的答案并不像知道文件名和行號那么簡單。用于版本控制、代碼重用和代碼組件重用以提高開發(fā)效率的代碼分支和合并允許缺陷進入多個版本和產(chǎn)品

考慮一個軟件團隊的情況,該團隊擁有多個產(chǎn)品的不同版本的分支。由于代碼復制,其中一個分支中的錯誤可能存在于一個或多個其他分支中。在另一種情況下,考慮創(chuàng)建框架以支持智能手機應用程序的團隊。因為他們可能將框架移植到 Windows、AndroidiPhone 等各種平臺上,所以靜態(tài)分析結(jié)果清楚地表明已識別的缺陷是僅存在于一個地方還是存在于多個平臺上,這一點至關(guān)重要。同樣,當軟件是通過從多個來源聚合創(chuàng)建的時,如果在各種產(chǎn)品中使用特定組件,那將是一場噩夢,因為一個第三方組件的缺陷最終可能會影響包含它的所有不同產(chǎn)品。

不同版本操作系統(tǒng)的多個分支

想象一個負責為移動智能手機創(chuàng)建新操作系統(tǒng) (OS) 的軟件開發(fā)團隊。由于必須支持多個手機供應商 (OEM),因此源代碼控制管理系統(tǒng)中的每個供應商都需要一個開發(fā)分支。此外,每個供應商通常都有針對不同版本和產(chǎn)品代的多個分支。畫面開始變得非常復雜。

對代碼的每個分支執(zhí)行的靜態(tài)分析會生成一個缺陷列表。但是,根據(jù)引入缺陷的時間,它可能存在于所有版本或子集中。當孤立地查看單個分支中的單個缺陷時,開發(fā)人員面臨的挑戰(zhàn)是他們無法在不知道缺陷存在于何處的情況下評估缺陷的嚴重性。不限于單個版本或一個 OEM 客戶端的缺陷將是嚴重的,修復它需要優(yōu)先于其他任何事情。此外,編寫代碼來修復缺陷的開發(fā)人員需要準確地知道需要簽入源代碼控制管理系統(tǒng)中的哪些分支。

圖 1:由于代碼分支和合并導致的重復缺陷。

poYBAGK6tOeAM116AAHt4wi8mqc418.png

適用于多個平臺的單一框架

在分支的另一面,通常需要編寫設計為在多個平臺上運行的代碼。諸如移動應用程序框架之類的軟件組件通常被構(gòu)建為在各種類型的移動電話平臺上運行。對于嵌入式設備,一個常見的要求是構(gòu)建相同代碼庫的 32 位和 64 位版本。我們舉一個簡單的例子:

gcc --m32 -c foo.c

// 32 位編譯。包含空指針取消引用缺陷。

gcc -c foo.c

// 64 位編譯。包含相同的空指針取消引用缺陷。

在 32 位和 64 位二進制文件中觸發(fā)的foo.c中的缺陷將被檢測并報告為單個缺陷。但是,由于源代碼相同,因此復雜的分析不會將其報告為重復缺陷。在失去開發(fā)人員對靜態(tài)分析解決方案的信任方面,重復與誤報一樣有害。

共享通用代碼組件

在最后一個示例中,考慮一個為一系列網(wǎng)絡交換機開發(fā)平臺軟件的團隊。由于平臺軟件提供的功能必須在所有產(chǎn)品中實現(xiàn),因此該代碼組件將被共享(參見圖 2)。對于在這個團隊工作的開發(fā)人員來說,靜態(tài)分析報告的缺陷嚴重性的最佳評估不僅是它對一個交換機產(chǎn)品的影響,還包括使用該平臺軟件組件的所有產(chǎn)品的信息。

圖 2:單個軟件組件在多個產(chǎn)品中重復使用。

pYYBAGK6tRCAFAMlAAFmrErrXjs168.png

產(chǎn)品通常是通過組合許多這樣的共享組件來創(chuàng)建的。每個組件不僅是一個項目本身,而且是使用它的各種其他項目的一部分。分析結(jié)果需要確定此共享組件中的缺陷對使用它的各個項目有影響。

消除代碼測試中的猜測

采用靜態(tài)分析等現(xiàn)代開發(fā)人員測試方法是嵌入式軟件行業(yè)的一個積極趨勢。該技術(shù)已經(jīng)成熟到可以成為軟件工程師武器庫中強大武器的程度。無需創(chuàng)建復雜的測試用例和測試基礎(chǔ)設施,靜態(tài)分析就可以在編寫和編譯代碼時自動發(fā)現(xiàn)關(guān)鍵缺陷。但是,要使靜態(tài)分析成為開發(fā)人員最有價值的工具,分析必須提供諸如“此缺陷的影響是什么?”之類的問題的答案。和“我需要在哪里檢查修復?” 幫助確定修復已識別缺陷的優(yōu)先級,并消除猜測以確保軟件盡可能無錯誤。

審核編輯:郭婷

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5087

    文章

    19153

    瀏覽量

    306432
  • Android
    +關(guān)注

    關(guān)注

    12

    文章

    3939

    瀏覽量

    127643
  • WINDOWS
    +關(guān)注

    關(guān)注

    4

    文章

    3553

    瀏覽量

    88993
收藏 人收藏

    評論

    相關(guān)推薦

    SQL錯誤代碼及解決方案

    SQL數(shù)據(jù)庫開發(fā)和管理,常見的錯誤代碼及其解決方案可以歸納如下: 一、語法錯誤(Syntax Errors) 錯誤代碼 :無特定
    的頭像 發(fā)表于 11-19 10:21 ?2346次閱讀

    用TPA4411過程中,發(fā)現(xiàn)靜態(tài)電流居然達100MA左右,為什么?

    用TPA4411過程中,發(fā)現(xiàn)靜態(tài)電流居然達100MA左右,這對電池供電的產(chǎn)品來說,要命啊,是芯片特性還是芯片問題?求解
    發(fā)表于 10-25 06:12

    汽車異構(gòu)硬件平臺開發(fā)如何進行靜態(tài)代碼分析

    先進的靜態(tài)代碼分析工具,其新版本引入的多CCT功能為開發(fā)人員提供了強大的支持,該功能不僅簡化了多編譯器環(huán)境下的代碼
    的頭像 發(fā)表于 10-09 16:15 ?552次閱讀
    汽車異構(gòu)硬件平臺開發(fā)如何進行<b class='flag-5'>靜態(tài)</b><b class='flag-5'>代碼</b><b class='flag-5'>分析</b>

    Perforce靜態(tài)分析工具2024.2新增功能:Helix QAC全新CI/CD集成支持、Klocwork分析引擎改進和安全增強

    實現(xiàn)持續(xù)合規(guī)性現(xiàn)代軟件開發(fā)實踐要求開發(fā)團隊具備適應性,確保代碼質(zhì)量和可靠性的同時,優(yōu)先考慮靈活性和協(xié)作性。軟件開發(fā)流程
    的頭像 發(fā)表于 10-08 16:22 ?312次閱讀
    Perforce<b class='flag-5'>靜態(tài)</b><b class='flag-5'>分析</b>工具2024.2新增功能:Helix QAC全新CI/CD集成支持、Klocwork<b class='flag-5'>分析</b>引擎改進和安全<b class='flag-5'>增強</b>

    LM5145pre-bias啟機過程中的電壓反灌問題

    電子發(fā)燒友網(wǎng)站提供《LM5145pre-bias啟機過程中的電壓反灌問題.pdf》資料免費下載
    發(fā)表于 09-27 10:19 ?0次下載
    LM5145<b class='flag-5'>在</b>pre-bias啟機<b class='flag-5'>過程中</b>的電壓反灌問題

    康謀分享 | 基于場景的AD/ADAS驗證過程中,識別挑戰(zhàn)性場景!

    基于場景的驗證是AD/ADAS系統(tǒng)開發(fā)過程中的重要步驟,然而面對海量駕駛記錄數(shù)據(jù)時,如何實現(xiàn)自動且高效地識別、分類和提取駕駛記錄的挑戰(zhàn)性場景?本文康謀為您介紹IVEX軟件識別挑戰(zhàn)性場景并進行數(shù)據(jù)
    的頭像 發(fā)表于 08-28 10:16 ?1118次閱讀
    康謀分享 | <b class='flag-5'>在</b>基于場景的AD/ADAS驗證<b class='flag-5'>過程中</b>,識別挑戰(zhàn)性場景!

    DevOps的質(zhì)量門工作原理,以及靜態(tài)代碼分析Klocwork和Perforce Helix QAC質(zhì)量門的實踐應用

    如何使用靜態(tài)代碼分析工具(如Klocwork 和 Helix QAC)實現(xiàn)質(zhì)量門。 什么是質(zhì)量門? 質(zhì)量門是IT或開發(fā)項目中實施的檢查點,這些檢查點要求
    的頭像 發(fā)表于 07-29 15:12 ?436次閱讀

    RIGOL產(chǎn)品材料應力測試過程中的應用

    、強度、剛度、穩(wěn)定性等,可以精確地控制產(chǎn)品質(zhì)量。本篇解決方案將介紹RIGOL產(chǎn)品材料應力測試過程中的應用。
    的頭像 發(fā)表于 07-12 17:01 ?333次閱讀
    RIGOL產(chǎn)品<b class='flag-5'>在</b>材料應力測試<b class='flag-5'>過程中</b>的應用

    定華雷達知識講堂:雷達物位計測量過程中的干擾有哪些?

    用戶介紹一下DHE雷達物位計測量過程中產(chǎn)生干擾的具體因素都有哪些。 一、DHE雷達物位計測量過程中,常見的干擾可分為兩種:直流干擾和交流干擾。 1、直流干擾? ? ???
    的頭像 發(fā)表于 06-26 16:03 ?391次閱讀

    Fx3控制器,USB數(shù)據(jù)包的數(shù)據(jù)有效載荷無法正常發(fā)送的原因?

    Fx3 控制器,流式傳輸過程中,從主機收到了意外的端點停止請求。 調(diào)試過程中,我發(fā)現(xiàn)
    發(fā)表于 05-28 06:37

    連焊如何在SMT加工過程中發(fā)生的?

    問題的嚴重性還是比較清楚的,也積極尋求解決方案。那么,連焊是如何在SMT加工過程中發(fā)生的呢?首先,我們要關(guān)注到焊接溫度和時間的影響。這兩個參數(shù)SMT加工起到至關(guān)重要的作
    的頭像 發(fā)表于 05-14 16:20 ?336次閱讀
    連焊如何在SMT加工<b class='flag-5'>過程中</b>發(fā)生的?

    量子計算最新突破 微軟與量子計算公司Quantinuum合作實現(xiàn)14000次實驗無錯誤

    微軟與量子計算公司Quantinuum深度合作,宣布實驗成功完成了多達14000次無錯誤的量子計算操作,刷新量子計算錯誤率紀錄,將錯誤
    的頭像 發(fā)表于 05-14 11:47 ?654次閱讀
    量子計算最新突破 微軟與量子計算公司Quantinuum合作實現(xiàn)14000次實驗<b class='flag-5'>無錯誤</b>

    STM32F103C8下載程序過程中中斷,然后上電運行MCU,此時MCU跑哪一段代碼

    STM32F103C8下載程序過程中中斷,然后上電運行MCU,此時,MCU跑哪一段代碼?有哪些外設在工作?多謝
    發(fā)表于 03-29 08:05

    介紹一些常見的Modbus IO通信錯誤代碼及其含義

    Modbus IO通信協(xié)議錯誤代碼通常用于標識通信過程中出現(xiàn)的錯誤或異常情況。
    的頭像 發(fā)表于 03-06 09:03 ?2749次閱讀

    STM32G431RB使用軟件生成代碼過程中報錯怎么解決?

    使用軟件生成代碼過程中報錯,使用但是STM32G431RB 的開發(fā)板
    發(fā)表于 03-06 06:15