国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

代碼檢查的方式有三種

jf_21561199 ? 來源:jf_21561199 ? 作者:jf_21561199 ? 2024-02-25 10:08 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

【摘要】代碼檢查中,提到的編程規范,規則集,規則,規則用例(場景、誤報、檢出)分別代表什么意思呢?

SAST 靜態檢查領域,代碼檢查服務可以幫助開發者發現和修復代碼中的風格、質量和安全等方面的問題。那么在代碼檢查服務中,提到的編程規范,規則集,規則,規則用例(場景、誤報、檢出)分別代表什么意思呢?

編程規范

在 SAST 靜態代碼檢查領域,編程規范是一套在組織層面關于代碼編寫的標準或準則。它可以幫助開發者遵循一致的風格和習慣,提高代碼的可讀性、可維護性、可移植性、安全性與可靠性,目的在于指導公司、部門、項目組編寫出 CleanCode 及高質量的軟件。

編程規范通常會參考業界標準及實踐,并包含命名、縮進、注釋、格式等方面的內容,業界內比較有名的有華為編程規范。

編程規范內的規則通常被用于在特定場景下使用,檢測出代碼中的漏洞和缺陷。但是這些規則并非就是萬能完美的,在一些場景下,可能會導致誤報率、漏報率高的情況發生。如果在日常使用中發現某些規則不適合或者無法遵循,經過團隊共同研討決策,是可以對規范中的規則進行改進甚至下線處理的。

注意,團隊內在使用編程規范的時候,是希望團隊成員都具有相應語言的基礎編程能力,而不是說希望通過編程規范來學習某個具體的語言。

規則集

規則集則是一組用于做代碼檢查的規則組成的集合。

一般根據不同的檢查目標和需求,規則集也有相應的分類,比如對安全類、安卓應用、編程風格這些類別進行檢查的時候,規則集內的規則也會有不同的選擇。

規則集可以應用在不同的范圍上,比如:公司最小規則集可以在全公司范圍內使用,產品線規則集則可以在最小規則集的基礎上再額外加些產品線特有的規則進去,構建一個范圍更大的產品線級規則集。

規則集也可以在不同的階段使用。比如針對本地 IDE 編碼階段,可以構建一個 IDE 插件檢查規則集在本地實時進行檢查。在提交增量代碼階段,使用一個更大范圍的規則集對增量代碼進行自動化檢查。在要進行版本級掃描階段,與流水線協同提供全面、深度的全量檢查。

wKgaomXYo62AeaT3AADeyFO_lyA012.png

華為云 CodeArtsCheck 的系統推薦規則集

規則

規則是一種用來指導和約束代碼檢查的標準和準則。它可以根據不同的編程語言、編碼規范、質量要求等因素來制定。每個規則可以說都定義了一個缺陷模式,當該模式在目標代碼中匹配成功后會生成一個檢查問題。

每個規則都會包含一個 ID 和一個操作。ID 可以說是規則唯一的標識符,用于區分不同的規則;操作則用于指定改規則在代碼檢查期間應該執行的動作,比如告警等。

規則一般會包含描述信息(包含編寫這條規則的背景等)、正確的代碼示例、錯誤的代碼示例、修復建議、參考的規范等信息。

wKgZomXYo62AYL81AADj2n83XMM218.png

華為云 CodeArtsCheck 的規則信息

規則用例

規則用例是一種用于驗證代碼檢查規則是否按照預期正確工作的測試用例。一般它會包括一個或多個測試輸入(代碼片段),執行條件以及預期的檢查結果(包括是否有問題,問題的類型,問題的位置等)。

規則用例可以說是檢驗和驗證規則的一種手段,可以幫助開發人員和測試人員評估代碼檢查規則的有效性、準確性和覆蓋性。

而和規則用例配套的術語則有:場景,誤報,檢出等。

場景

場景是一種描述代碼檢查規則應用的具體情況或背景的方法,它可以說是規則用例的集合(包含 1 個或多個規則用例)以及一些相關的信息(項目類型、編程語言、編碼規范等)的結合。場景可以比規則用例更全面的模擬代碼檢查規則的使用場景。

誤報

誤報是指代碼檢查服務錯誤地報告了一個不存在的問題或一個錯誤的問題類型的狀況。誤報一般是由于代碼檢查規則的設計缺陷、實現錯誤、使用場景不匹配或配置不當等原因造成的,會導致開發人員和測試人員對代碼檢查服務的信任度降低。

檢出

檢出則和誤報完全相反,是個好的現象,是指代碼檢查服務正確地報告了一個確實存在的問題及正確的問題類型的狀況。檢出高可以幫助開發人員預防和修復潛在的缺陷。

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 代碼
    +關注

    關注

    30

    文章

    4968

    瀏覽量

    73969
  • 華為云
    +關注

    關注

    3

    文章

    2832

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    AI技術時代三種全新工作模式如何實現

    AI技術正在重塑我們的工作。前沿企業以“人類主導、智能體運營”為核心,形成三種AI技術的融合模式:人類+AI技術助手、人機混合、人類主導智能體運營,這些模式不僅提升效率,更在重構協作方式,幫助組織以更低的阻力邁向成功。
    的頭像 發表于 01-29 15:08 ?505次閱讀

    C語言中實現函數宏的三種方式

    在宏的第一個分號后便結束。即 a = b 和 b = tmp 均不受控制語句所作用。 因此,在工程中,一般使用三種方式來對函數宏進行封裝,分別為 {}、do{...}while(0
    發表于 12-29 07:34

    請問CW32芯片的三種工作模式是什么?

    CW32芯片的三種工作模式是什么?
    發表于 12-26 06:48

    伺服電機的三種制動方式什么區別?

    伺服電機作為自動化控制系統中執行元件的核心部件,其制動性能直接影響設備的定位精度和安全可靠性。目前主流的伺服電機制動方式包括動態制動、再生制動和電磁機械制動三種,它們在制動原理、應用場景及技術特點上
    的頭像 發表于 09-19 18:26 ?1758次閱讀
    伺服電機的<b class='flag-5'>三種</b>制動<b class='flag-5'>方式</b><b class='flag-5'>有</b>什么區別?

    TC377配置SMU FSP時,如何配置頻率參數;三種模式何區別,配置上有何區別?

    TC377配置SMU FSP時,如何配置頻率參數;三種模式何區別,配置上有何區別?
    發表于 08-08 07:48

    MEMS中的三種測溫方式

    在集成MEMS芯片的環境溫度測量領域,熱阻、熱電堆和PN結原理是三種主流技術。熱阻是利用熱敏電阻,如金屬鉑或注入硅的溫度電阻系數恒定,即電阻隨溫度線性變化的特性測溫,電阻變化直接對應絕對溫度,需恒流源供電。
    的頭像 發表于 07-16 13:58 ?1667次閱讀
    MEMS中的<b class='flag-5'>三種</b>測溫<b class='flag-5'>方式</b>

    1553B總線常見三種組網方式

    1553B總線作為航空電子系統中的關鍵通信協議,其組網方式直接影響系統的可靠性和實時性。本文將深入解析1553B總線的三種典型組網結構:單總線結構、雙冗余總線和多總線分層架構,并結合實際應用場景分析
    的頭像 發表于 06-21 17:39 ?1934次閱讀
    1553B總線常見<b class='flag-5'>三種</b>組網<b class='flag-5'>方式</b>

    開關電源三種控制模式:PWM/PFM/PSM

    PWM/PFM/PSM 三種控制模式的定義通常來說,開關電源(DC-DC)三種最常見的調制方式分別為: 脈沖寬度調制(PWM) 脈沖頻率調制(PFM) 脈沖跨周期調制(PSM)
    發表于 06-09 16:11

    HarmonyOS基礎組件:Button三種類型的使用

    中的Button相較于Android原生來說,功能比較豐富,擴展性高,減少了開發者的代碼數量,簡化了使用方式。不僅可以自定義圓角還支持三種樣式。 常用屬性 名稱 參數類型 描述 type
    的頭像 發表于 06-09 15:48 ?2614次閱讀
    HarmonyOS基礎組件:Button<b class='flag-5'>三種</b>類型的使用

    介紹三種常見的MySQL高可用方案

    在生產環境中,為了確保數據庫系統的連續可用性、降低故障恢復時間以及實現業務的無縫切換,高可用(High Availability, HA)方案至關重要。本文將詳細介紹三種常見的 MySQL 高可用
    的頭像 發表于 05-28 17:16 ?1240次閱讀

    信號隔離器三種供電方式的區別

    信號隔離器是一重要的信號隔離裝置,其供電方式主要有獨立供電、回路供電和輸出回路供電三種。以下是這三種供電方式的詳細區別: 一、獨立供電 1
    的頭像 發表于 04-17 16:23 ?1543次閱讀
    信號隔離器<b class='flag-5'>三種</b>供電<b class='flag-5'>方式</b>的區別

    redis三種集群方案詳解

    在Redis中提供的集群方案總共有三種(一般一個redis節點不超過10G內存)。
    的頭像 發表于 03-31 10:46 ?1533次閱讀
    redis<b class='flag-5'>三種</b>集群方案詳解

    CMOS,Bipolar,FET這三種工藝的優缺點是什么?

    在我用photodiode工具選型I/V放大電路的時候,系統給我推薦了AD8655用于I/V,此芯片為CMOS工藝 但是查閱資料很多都是用FET工藝的芯片,所以請教下用于光電信號放大轉換(主要考慮信噪比和帶寬)一般我們用哪種工藝的芯片, CMOS,Bipolar,FET這三種工藝的優缺點是什么?
    發表于 03-25 06:23

    GaN、超級SI、SiC這三種MOS器件的用途區別

    如果想要說明白GaN、超級SI、SiC這三種MOS器件的用途區別,首先要做的是搞清楚這三種功率器件的特性,然后再根據材料特性分析具體應用。
    的頭像 發表于 03-14 18:05 ?2722次閱讀

    FOC中的三種電流采樣方式,你真的會選擇嗎?(可下載)

    的基礎,用一句話來形容就是“基礎不對,努力白費”,由此可見電流采樣在整 個 FOC 算法中的作用電流采樣的方式一般分為電阻、雙電阻、單電阻,這三種采樣方式都有其
    發表于 03-12 15:04 ?4次下載