91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

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

星星科技指導(dǎo)員 ? 來源:嵌入式計算設(shè)計 ? 作者:Rutul Dave ? 2022-06-28 15:58 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

圖 1:由于代碼分支和合并導(dǎo)致的重復(fù)缺陷。

poYBAGK6tOeAM116AAHt4wi8mqc418.png

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

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

gcc --m32 -c foo.c

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

gcc -c foo.c

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

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

共享通用代碼組件

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

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

pYYBAGK6tRCAFAMlAAFmrErrXjs168.png

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

消除代碼測試中的猜測

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

審核編輯:郭婷

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

    關(guān)注

    5200

    文章

    20481

    瀏覽量

    334531
  • Android
    +關(guān)注

    關(guān)注

    12

    文章

    4028

    瀏覽量

    134077
  • WINDOWS
    +關(guān)注

    關(guān)注

    4

    文章

    3702

    瀏覽量

    94106
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    HPM知識庫 | [EtherCAT] 從站運(yùn)行過程中報錯(錯誤碼:0x1A\\0x1B\\0x2C)的代碼分析

    ://kb.hpmicro.com/一、背景本文將以SSC從站協(xié)議棧代碼為例,分析EtherCAT從站運(yùn)行過程中報錯(錯誤碼:0x1A\0x1B\0x2C),說明協(xié)議棧的檢測
    的頭像 發(fā)表于 03-13 08:34 ?33次閱讀
    HPM知識庫 | [EtherCAT] 從站運(yùn)行<b class='flag-5'>過程中</b>報錯(<b class='flag-5'>錯誤</b>碼:0x1A\\0x1B\\0x2C)的<b class='flag-5'>代碼</b><b class='flag-5'>分析</b>

    分析嵌入式軟件代碼的漏洞-代碼注入

    惡意的互聯(lián)網(wǎng)環(huán)境確保他們的嵌入式代碼能夠安全使用的開發(fā)人員,應(yīng)該將這樣的代碼注入漏洞,開發(fā)周期和嚴(yán)格的代碼檢查
    發(fā)表于 12-22 12:53

    請問如何解決CW32L083系列微控制器通信過程中可能出現(xiàn)的數(shù)據(jù)錯誤問題?

    如何解決CW32L083系列微控制器通信過程中可能出現(xiàn)的數(shù)據(jù)錯誤問題?
    發(fā)表于 12-16 08:01

    程序加載過程中遇到的問題及其解決方法

    程序顯示JTAG all ones,報錯界面如下圖所示。 硬件電路,MCU被設(shè)計為上電即從Flash讀取代碼并開始運(yùn)行,如果寫入MCU Flash
    發(fā)表于 10-30 07:59

    UPS不間斷電源放電過程中的注意事項

    UPS日常的使用過程中,只有定期對UPS放電才能延長UPS的使用壽命,UPS 電源電池需要每三個月進(jìn)行一次充放電,怎樣對UPS進(jìn)行放電才能讓其保持最佳工作狀態(tài)? 現(xiàn)在,由匯智天源工程師和大家聊一
    的頭像 發(fā)表于 10-11 11:33 ?664次閱讀
    UPS不間斷電源<b class='flag-5'>在</b>放電<b class='flag-5'>過程中</b>的注意事項

    lv_port_disp_init();使用lvgl時移植過程中這個函數(shù)報錯怎么解決?

    lv_port_disp_init();使用lvgl時移植過程中這個函數(shù)報錯怎么解決
    發(fā)表于 09-19 07:35

    紅外測溫技術(shù)氣瓶充裝過程中的應(yīng)用

    氣瓶充裝過程中,溫度異??赡芤l(fā)瓶體爆裂、氣體泄漏等嚴(yán)重事故,直接威脅人員與生產(chǎn)安全。而紅外測溫技術(shù)的應(yīng)用,正成為實時監(jiān)控溫度、防范風(fēng)險的“利器”。
    的頭像 發(fā)表于 08-26 15:54 ?905次閱讀

    靜力水準(zhǔn)儀測量過程中遇到誤差如何處理?

    靜力水準(zhǔn)儀測量過程中遇到誤差如何處理?靜力水準(zhǔn)儀工程沉降監(jiān)測中出現(xiàn)數(shù)據(jù)偏差時,需采取系統(tǒng)性處理措施。根據(jù)實際工況,誤差主要源于環(huán)境干擾、設(shè)備狀態(tài)、安裝缺陷及操作不當(dāng)四類因素,需針對性解決。靜力
    的頭像 發(fā)表于 08-14 13:01 ?889次閱讀
    靜力水準(zhǔn)儀<b class='flag-5'>在</b>測量<b class='flag-5'>過程中</b>遇到誤差如何處理?

    汽車軟件團(tuán)隊必看:基于靜態(tài)代碼分析工具Perforce QAC的ISO 26262合規(guī)實踐

    ISO 26262合規(guī)指南,從ASIL分級到工具落地,手把手教你用靜態(tài)代碼分析(Perforce QAC)實現(xiàn)高效合規(guī)。
    的頭像 發(fā)表于 08-07 17:33 ?1180次閱讀
    汽車<b class='flag-5'>軟件</b>團(tuán)隊必看:基于<b class='flag-5'>靜態(tài)</b><b class='flag-5'>代碼</b><b class='flag-5'>分析</b>工具Perforce QAC的ISO 26262合規(guī)實踐

    超聲波清洗機(jī)如何在清洗過程中減少廢液和對環(huán)境的影響?

    超聲波清洗機(jī)如何在清洗過程中減少廢液和對環(huán)境的影響隨著環(huán)保意識的增強(qiáng),清洗過程中的廢液處理和環(huán)境保護(hù)變得越來越重要。超聲波清洗機(jī)作為一種高效的清洗技術(shù),也不斷發(fā)展以減少廢液生成和對環(huán)
    的頭像 發(fā)表于 06-16 17:01 ?685次閱讀
    超聲波清洗機(jī)如何在清洗<b class='flag-5'>過程中</b>減少廢液和對環(huán)境的影響?

    盟通方案|專業(yè)的CANopen總線分析軟件

    CAN/CANopen產(chǎn)品開發(fā)過程中,數(shù)據(jù)分析是非常關(guān)鍵的一環(huán)。數(shù)據(jù)幀分析軟件就如您工作的萬
    的頭像 發(fā)表于 05-23 16:06 ?802次閱讀
    盟通方案|專業(yè)的CANopen總線<b class='flag-5'>分析</b><b class='flag-5'>軟件</b>

    原理圖和PCB設(shè)計的常見錯誤

    電子設(shè)計領(lǐng)域,原理圖和PCB設(shè)計是產(chǎn)品開發(fā)的基石,但設(shè)計過程中難免遇到各種問題,若不及時排查可能影響電路板的性能及可靠性,本文將列出原理圖和PCB設(shè)計的常見錯誤,整理成一份實用的速
    的頭像 發(fā)表于 05-15 14:34 ?1236次閱讀

    單元測試嵌入式軟件的關(guān)鍵作用及winAMS工具的卓越貢獻(xiàn)

    1.?單元測試概述 ?定義與核心目標(biāo)? 單元測試是軟件開發(fā)過程中針對程序模塊(如函數(shù)、類或組件)的最小可測試單元進(jìn)行的驗證活動。其核心目標(biāo)在于隔離代碼片段,驗證其功能是否符合設(shè)計預(yù)期,從而在早期階段
    的頭像 發(fā)表于 04-11 14:31 ?1070次閱讀

    半導(dǎo)體制造過程中的三個主要階段

    前段工藝(Front-End)、中段工藝(Middle-End)和后段工藝(Back-End)是半導(dǎo)體制造過程中的三個主要階段,它們制造過程中扮演著不同的角色。
    的頭像 發(fā)表于 03-28 09:47 ?7529次閱讀
    半導(dǎo)體制造<b class='flag-5'>過程中</b>的三個主要階段

    請問NXP板的BSP QA過程中采用了哪些具體的測試方法?

    QA 過程中采用了哪些特定的測試方法? 什么是 QA 流程,以及 yocto/linux BSP 整個 QA 生命周期中如何跟蹤和管理缺陷? RSB 3720 板的 QA 流程中使用了
    發(fā)表于 03-17 08:04