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

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

3天內不再提示

如何成為更好的防御性程序員 5個小技巧

PCB線路板打樣 ? 來源:LONG ? 2019-08-09 10:18 ? 次閱讀

在實驗室中有效的方法并不總是在現場工作,通常是由于意外的交互和未發(fā)現的錯誤。防御性編程可以幫助提高設計的彈性,但開發(fā)能夠處理不可預見情況的嵌入式軟件并非易事;它需要紀律和深謀遠慮。以下是幫助開發(fā)人員成為更好的防御性程序員的五個技巧。

技巧1 -校驗和或CRC數據

使用校驗和和循環(huán)冗余校驗( CRC)算法是開發(fā)人員驗證通過串行鏈路發(fā)送的數據確實正確的好方法。經過審查的嵌入式系統(tǒng)在測試臺的受控環(huán)境中始終表現如預期。然而,一旦系統(tǒng)被釋放到野外,系統(tǒng)運行的環(huán)境就變得非常未知。嘈雜的環(huán)境可能會產生通信噪聲,導致位翻轉和誤讀數據。檢測此損壞數據的最佳希望是通過使用校驗和或CRC對數據進行健全性檢查。

提示2 -按合同設計

按合同設計是一種開發(fā)軟件的方法,可以生成高度定義的軟件界面,每個函數都與之相關聯具有明確的前提條件和后置條件。我們的想法是,如果應用程序要調用特定函數,則調用應用程序必須滿足函數的前置條件才能獲得有效的響應或操作。按合同設計對開發(fā)人員來說可能是一個強大的工具,因為它明確指定了函數期望接收的內容以及有效前置條件下的保證輸出。由于期望不是“在線之間讀取”,因此調用該函數的開發(fā)人員確切地知道了使用該函數的期望是什么。

技巧3 -使用斷言

斷言宏是開發(fā)人員驗證其應用假設的好方法在應用程序中的給定點。斷言的使用對于在bug發(fā)生時捕獲程序中的錯誤和意外行為非常有用。斷言甚至可以在契約式設計環(huán)境中使用,以驗證合同的前提條件和后置條件是否已得到滿足。有關在嵌入式軟件中使用斷言的介紹,請考慮閱讀8個使用C中的斷言和何時斷言或不斷言來壓縮錯誤的提示。

提示4 -檢查指針和緩沖區(qū)

指針和緩沖區(qū)是開發(fā)人員似乎總是遇到麻煩的兩個地方。在C中開發(fā)嵌入式系統(tǒng)時,很容易意外地取消引用NULL指針或溢出緩沖區(qū)。防御程序員應該在取消引用之前檢查指針的有效性。指針是否為NULL?不要去除它!存儲在指針中的值是否為有效值?如果是,則取消引用。

指針算法和數組的使用也很危險。開發(fā)人員應該在緩沖區(qū)和指針算術運算中添加邊界檢查,以確保結果保留在它們應該的內存空間內。意外地僅通過一個字節(jié)覆蓋內存可能會對嵌入式系統(tǒng)產生災難性后果,更重要的是會對其用戶造成災難性后果。

提示5 -使用堆棧監(jiān)視器

執(zhí)行最壞情況的堆棧分析并正確調整堆棧大小是一項艱巨的任務。通常,堆棧的大小要么保留在編譯器的默認設置中,要么開發(fā)人員在一張紙上寫下幾個可能的值并使用“eeny meeny miny moe”技術。這兩種技術都不夠,堆棧溢出的最壞情況成為現實。

開發(fā)人員可以通過監(jiān)視此類事件來幫助防止堆棧溢出。大多數實時操作系統(tǒng)都內置了堆棧監(jiān)視器。啟用堆棧監(jiān)視器只不過是使用RTOS的配置調整宏。在裸機系統(tǒng)中,開發(fā)人員需要更加積極主動,并且要么自己編寫堆棧監(jiān)視器,要么使用可以在Internet上找到的許多可用堆棧監(jiān)視器之一。要了解有關堆棧監(jiān)視器的更多信息,請考慮通過七個簡單步驟閱讀創(chuàng)建堆棧監(jiān)視器并使用堆棧防護改進代碼完整性

最后的想法

這五個技巧只是開發(fā)人員如何通過防御性編程改進嵌入式軟件的幾個例子。還有許多其他技術,例如編寫安全代碼和加密數據,這些技術可以幫助提高嵌入式系統(tǒng)即使在不可預見的情況下也能繼續(xù)運行的機會。

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

    關注

    4

    文章

    949

    瀏覽量

    29745
  • PCB打樣
    +關注

    關注

    17

    文章

    2968

    瀏覽量

    21625
  • 華強PCB
    +關注

    關注

    8

    文章

    1831

    瀏覽量

    27700
  • 華強pcb線路板打樣

    關注

    5

    文章

    14629

    瀏覽量

    42946
收藏 人收藏

    評論

    相關推薦

    成為優(yōu)秀程序員的條件(下)

    (接“成為優(yōu)秀程序員的條件(上))7 需求理解能力。程序員需要理解一模塊的需求,評估該模塊在系統(tǒng)運營中所處的環(huán)境8 復用,模塊化思維能力
    發(fā)表于 08-22 11:52

    嵌入式開發(fā)中防御性編程的要求

    的檢查十分弱小,需要程序員謹慎的考慮代碼,在必要的時候增加判斷;防御性編程的另一核心思想是假設代碼運行在并不可靠的硬件上,外接干擾有可能會打亂程序執(zhí)行順序、更改RAM存儲數據等等。1
    發(fā)表于 12-15 07:20

    程序員需要學什么,微軟資深程序員學習手冊面試寶典資料

    程序員是現在比較吃香的工作。程序員工資高還不需要和復雜的社會打交道。那么怎么成為一名程序員?當程序員需要學什么?
    發(fā)表于 03-22 11:54 ?30次下載

    成為優(yōu)秀程序員的7方法

    程序員總是有很多的決定,不是嗎?如果你的新年待辦事項還是空白的話,那么可以考慮使用下面這些程序員的想法。即使是最聰明的人,也還有成長空間。以下內容摘錄自 Kevlin Henney 的《程序員應該知道的97件事》。
    的頭像 發(fā)表于 11-21 11:18 ?1318次閱讀

    10倍效率程序員是否真的存在

    在編程神話中,一 10 倍效率的程序員可以完成一普通程序員 10 倍的工作量?!钙胀?b class='flag-5'>程序員」就是指,善于完成工作但沒有 10 倍效率
    的頭像 發(fā)表于 10-30 11:50 ?2001次閱讀

    程序員如何定義

    當了幾年的程序員了,一直都在想一問題,什么是程序員,程序員應該做好那些事情,什么樣的程序員是有素質的
    的頭像 發(fā)表于 12-18 14:15 ?2579次閱讀

    Java程序員學習的6小技巧

    知識改變命運,對于Java程序員來說,技術不斷更新,只有及時充電,才能不被市場淘汰。今天為大家分享Java程序員學習的6小技巧。
    的頭像 發(fā)表于 02-11 16:11 ?2452次閱讀

    怎樣成為合格的程序員

    偶爾的,我會被人問道:如何成為一名優(yōu)秀的程序員,更或者,如何成為一名程序員。每次人們問起,我都力圖給出不同的答案。因此,我的答案是各種各樣的。下面就是我認為的
    的頭像 發(fā)表于 04-15 16:32 ?1499次閱讀

    菜鳥程序員和大神程序員的差距

    剛剛走出就業(yè)的程序員,技術是剛剛起步的基點。那下面我們就聊一聊有關技術的東西。首先請您先想想這幾個問題。現在社會上有很多程序員,CSDN就是我們程序員的家,那您是否可想過程序員為什么會
    的頭像 發(fā)表于 06-03 15:56 ?2496次閱讀

    什么是程序員

    當了幾年的程序員了,一直都在想一問題,什么是程序員,程序員應該做好那些事情,什么樣的程序員是有素質的
    的頭像 發(fā)表于 06-04 16:21 ?8879次閱讀

    為什么要成為高級程序員

    程序員到高級程序員的職業(yè)生涯要經歷以下幾個階段:初級程序員、中級程序員、最后是高級程序員。
    的頭像 發(fā)表于 07-11 16:51 ?2399次閱讀

    怎樣成為優(yōu)秀的程序員

    每次我曾經的同學打電話向我詢問程序員這個行業(yè)怎么樣,我都會很耐心的講上一半小時,談人生談理想,并判斷他是否適合程序員這個行業(yè)。
    的頭像 發(fā)表于 10-23 16:26 ?2084次閱讀

    怎樣成為頂尖的程序員

    在IT行業(yè)飛速發(fā)展的時代,有過的程序員,有些成為程序員心中的大神,那么那些成為大神的程序員們是因為什么
    的頭像 發(fā)表于 11-06 16:12 ?2940次閱讀

    成為優(yōu)秀程序員必須知道的7好習慣

    作為一從業(yè)快10年的程序員,我想給新入行的程序員們一些建議。這些建議是我希望自己可以在畢業(yè)時就讀到的,也希望它們可以幫助你成為
    的頭像 發(fā)表于 01-06 16:09 ?2935次閱讀

    代碼防御性編程不得不知的技巧

    1 什么是防御性編程?顧名思義,防御性編程是一種細致、謹慎的編程方法。為了開發(fā)可靠的軟件,我們要設計系統(tǒng)中的每個組件,以使其盡可能的”保護”自己。我們通過明確地在代碼中對設想進行檢查,這是一種努力
    的頭像 發(fā)表于 11-22 09:49 ?1372次閱讀