一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

MISRA編碼標準和靜態(tài)代碼分析器

星星科技指導員 ? 來源:嵌入式計算設(shè)計 ? 作者: Ekaterina Nikiforova ? 2022-06-30 14:45 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

近年來,軟件質(zhì)量、安全和保障已成為重中之重。在我們之前的文章中,我們已經(jīng)提到了歷史上的一些事件,這些事件既造成了巨大的經(jīng)濟損失,也造成了人員死亡。Ariane 5的爆炸,Therac-25放射治療機使患者暴露于 20,000 拉德的過量劑量,89 人因豐田的過錯而死亡。所有這些故事都有一個共同點:導致巨大損失的軟件錯誤。

那么什么是 MISRA?

最初,MISRA(汽車行業(yè)軟件可靠性協(xié)會)成立的目的是為道路車輛中使用的微控制器設(shè)計一套軟件開發(fā)指南。從那時起,它就被應用于汽車工業(yè)、醫(yī)療設(shè)備、航空航天和國防等所有對可靠性和安全性至關(guān)重要的領(lǐng)域。MISRA 標準是由一組規(guī)則和建議組成的文檔,C 和 C++ 開發(fā)人員在開發(fā)其應用程序時應遵守這些規(guī)則和建議。MISRA-C:1998 版本有127條規(guī)則。

所有這些規(guī)則都可以分為以下幾類:

強制的

必需 – 允許偏離規(guī)則(但建議記錄在案)

咨詢——非強制性

(來源: 什么是 MISRA 以及如何烹飪)

首先要提到的是,MISRA 標準的應用應該在開發(fā)過程真正開始之前就開始,并且只有在真正需要的時候才開始。在其他情況下,特別是當代碼庫足夠大并且不打算在嵌入式系統(tǒng)上使用時,開發(fā)人員將不得不進行漫長而乏味的重構(gòu)。為什么這樣?

WinMerge 的源代碼長約 25 萬行 C 和 C++ 代碼。這是一個小項目,但是將if語句的主體括在花括號中的規(guī)則在其中被破壞了大約 2000 次。有 127-228 條這樣的規(guī)則(取決于標準的版本)。

Nana 是一個用于創(chuàng)建圖形用戶界面的跨平臺庫,其源代碼長度不到 10 萬行。在這個項目中,同樣的規(guī)則被打破了大約三千次。

除了關(guān)于花括號的規(guī)則之外,還有一些規(guī)則:

不得使用 continue 語句;

每個 switch 語句都應該有一個默認標簽;

不得使用 goto 語句;

所有 if 。.. else if 結(jié)構(gòu)都應以 else 子句終止;

那么,它是用來做什么的呢?

但是,這些規(guī)則并不意味著讓開發(fā)人員的生活更加艱難。這些是用鮮血寫成的規(guī)則,它們用于使安全關(guān)鍵代碼不易出現(xiàn)錯誤。這個想法是簡單而清晰的代碼不太可能包含錯誤。以下是一些作為證據(jù)的診斷示例:

賦值運算符不得用于返回布爾值的表達式;

所有非 void 的函數(shù)都應該返回一個值;

循環(huán)計數(shù)器不應具有本質(zhì)上的浮動類型;

一個函數(shù)最后應該有一個退出點;

遵循 MISRA 指南將有助于提高軟件的可靠性。但是,不熟悉 MISRA 的人可能想知道它是如何使用的。你真的必須記住所有這 127 條規(guī)則嗎?這就是靜態(tài)分析器可以提供幫助的地方。

靜態(tài)分析的目的是什么?

手動檢查代碼是否符合 MISRA 標準是一項漫長而乏味的工作。但實際上你不必記住所有這些規(guī)則。靜態(tài)代碼分析器可以為您完成所有工作。

靜態(tài)代碼分析是檢測計算機程序源代碼中的錯誤和小缺陷的過程。它可以被視為自動代碼審查。一些靜態(tài)分析器可以檢查代碼是否符合 MISRA 規(guī)則,正是這些工具將幫助您找到并修復程序中所有不符合規(guī)則的點。為此,您只需使用分析儀檢查您的項目并研究檢查結(jié)束時生成的分析報告。下面我將簡要演示如何使用 PVS-Studio 分析器和項目 Shairport 作為示例來執(zhí)行此操作。PVS-Studio 可在此處下載。

克隆存儲庫。

pYYBAGK9Rq6AIaujAAE-aWH--yw308.png

運行構(gòu)建配置腳本。

poYBAGK9RriASXBeAAF900aVcks432.png

在跟蹤模式下運行 PVS-Studio 并構(gòu)建項目。

poYBAGK9RsGAXSjhAASMtsi8K7Q047.png

根據(jù)上一步的結(jié)果分析項目文件。

poYBAGK9RsmAN4kbAANhT7WmPYM112.png

將日志轉(zhuǎn)換為 html。

poYBAGK9RtOANvczAAFj9JPDt4k863.png

完畢。我們現(xiàn)在可以查看日志。

pYYBAGK9RtuAHx02AAR-jZpO5eI066.png

所以,我們今天了解了 MISRA:我們查看了一些規(guī)則,討論了為什么需要這些指南,如何將它們應用到您的項目中,等等。我希望這篇文章足夠有趣,不會讓你昏昏欲睡,而且仍然能提供豐富的信息,讓作者的工作值得。希望現(xiàn)在您對 MISRA 是什么以及需要什么靜態(tài)代碼分析器有了更好的理解。

審核編輯:郭婷

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

    關(guān)注

    48

    文章

    7951

    瀏覽量

    154961
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2119

    瀏覽量

    75283
  • 源代碼
    +關(guān)注

    關(guān)注

    96

    文章

    2953

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    Helix QAC 2025.1 重磅發(fā)布!MISRA C:2025? 100%覆蓋

    和服務存儲占用。? 編碼規(guī)范支持(MISRA C:2025?、CERT C)? ? MISRA C:2025? 全規(guī)范覆蓋 Helix QAC 2025.1 提供全新的 MC25CM
    的頭像 發(fā)表于 05-13 16:48 ?418次閱讀
    Helix QAC 2025.1 重磅發(fā)布!<b class='flag-5'>MISRA</b> C:2025? 100%覆蓋

    MISRA C:2025新標準解析:新增規(guī)則、優(yōu)化點與靜態(tài)代碼分析工具支持(Perforce QAC、Klocwork)

    MISRA C:2025?發(fā)布!新增5條規(guī)則,并對部分現(xiàn)有規(guī)則進行了擴展、重組,以進一步簡化安全關(guān)鍵型系統(tǒng)的開發(fā)流程。如何實現(xiàn)最新MISRA合規(guī)性?
    的頭像 發(fā)表于 05-08 17:58 ?863次閱讀
    <b class='flag-5'>MISRA</b> C:2025新<b class='flag-5'>標準</b>解析:新增規(guī)則、優(yōu)化點與<b class='flag-5'>靜態(tài)</b><b class='flag-5'>代碼</b><b class='flag-5'>分析</b>工具支持(Perforce QAC、Klocwork)

    使用BCU和標準邏輯分析儀Saleae進行功率測量時不匹配怎么解決?

    ” - “V_sense-” = 16 mV 所以,我不確定我遵循的程序是否有任何問題”薩萊“是一個標準的邏輯分析器,理想情況下不應該有任何這樣的錯誤。 那么有人可以幫我解決這個問題嗎?
    發(fā)表于 04-04 08:07

    VirtualLab Fusion應用:光柵級次分析器

    VirtualLab Fusion中也可用。這種全矢量方法的結(jié)果是復數(shù)瑞利系數(shù),它包含每階所需的所有場信息,從中可以獲得相應的效率。VirtualLab Fusion中的光柵順序分析器幫助我們生成并以圖像方式
    發(fā)表于 02-11 09:47

    用于 SPI 絕對編碼器的 Arduino 示例代碼

    (SPI) 通信來配置和讀取 [Same Sky] 的 [AMT22 絕對編碼器] 的數(shù)據(jù)。該教程將提供所需的硬件和軟件、關(guān)鍵設(shè)置要求以及單圈和多圈輸出選項的示例代碼包和說明。以下是入門工作所需的物料清單
    的頭像 發(fā)表于 01-26 21:35 ?803次閱讀
    用于 SPI 絕對<b class='flag-5'>編碼器</b>的 Arduino 示例<b class='flag-5'>代碼</b>

    VirtualLab:系統(tǒng)建模分析器

    ,系統(tǒng)建模分析器。本文檔介紹該工具的使用方法。 系統(tǒng)建模分析器 如何運行建模分析器 系統(tǒng)建模分析器 例1:光束清理濾波 示例 – 光
    發(fā)表于 01-14 09:45

    偏振分析器

    摘要 線柵偏振,可以使透射光產(chǎn)生線性偏振狀態(tài),是眾多應用中常見的一種光學元件。由于它們的結(jié)構(gòu)在亞波長范圍內(nèi),因此必須對光的傳播進行嚴格的處理。VirtualLab的偏振分析器及其內(nèi)置的RCWA
    發(fā)表于 01-13 08:59

    VirtualLab Fusion:系統(tǒng)建模分析器

    ,系統(tǒng)建模分析器。本文檔介紹該工具的使用方法 系統(tǒng)建模分析器 如何運行建模分析器 系統(tǒng)建模分析器 例1:光束清理濾波 示例 – 光束
    發(fā)表于 01-04 08:45

    VirtualLab:系統(tǒng)建模分析器

    ,系統(tǒng)建模分析器。本文檔介紹該工具的使用方法。 系統(tǒng)建模分析器 如何運行建模分析器 系統(tǒng)建模分析器 例1:光束清理濾波 示例 – 光
    發(fā)表于 12-19 12:36

    如何測試TPA3118和TPA3116的靜態(tài)電流和靜態(tài)功耗?

    1.如何測試TPA3118和TPA3116的靜態(tài)電流和靜態(tài)功耗? 2.測試時候需要帶負載嘛?(是否需要接喇叭) 3.如果用萬用表測試應該怎么測?
    發(fā)表于 10-12 06:54

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

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

    傳感的動態(tài)特性和靜態(tài)特性參數(shù)介紹

    傳感的特性可以分為靜態(tài)特性和動態(tài)特性兩大類,這兩類特性分別描述了傳感在不同輸入條件下的輸出響應特點。下面將詳細介紹這兩類特性的主要參數(shù)。
    的頭像 發(fā)表于 09-29 16:24 ?5803次閱讀

    embOS的MISRA-C:2012一致性

    MISRA C是汽車工業(yè)軟件可靠性協(xié)會(MISRA)開發(fā)的一套針對C編程語言的軟件開發(fā)指南,目的是提升嵌入式系統(tǒng)的安全性和可移植性。2012發(fā)布的MISRA C第三版,稱為MISRA
    的頭像 發(fā)表于 08-20 11:35 ?871次閱讀

    whitepaper-perforce-what-is-misra

    如果您熟悉嵌入式軟件的世界,您可能聽說過安全關(guān)鍵系統(tǒng)的MISRA編碼準則和合規(guī)性。最初為在汽車嵌入式軟件行業(yè),MISRA C for C 和 C++ 被廣泛使用嵌入式行業(yè),從航空航天和國防到醫(yī)療設(shè)備。本文提供
    發(fā)表于 08-08 15:54 ?0次下載

    暫態(tài)穩(wěn)定和靜態(tài)穩(wěn)定的區(qū)別是什么

    暫態(tài)穩(wěn)定和靜態(tài)穩(wěn)定是電力系統(tǒng)穩(wěn)定性分析中的兩個重要概念,它們分別描述了電力系統(tǒng)在受到擾動后的動態(tài)響應和穩(wěn)態(tài)運行狀態(tài)。下面將介紹暫態(tài)穩(wěn)定和靜態(tài)穩(wěn)定的區(qū)別,并從多個方面進行比較。 定義上的區(qū)別 暫態(tài)穩(wěn)定
    的頭像 發(fā)表于 07-26 09:41 ?4897次閱讀