自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

美國航天局的十大編碼戒律

開發(fā) 后端 前端
美國航空航天局(NASA,以下皆用英文簡稱)有一套自己的編碼標準,以確保所有NASA應(yīng)用的代碼質(zhì)量和安全。這些標準漸漸演變適用于廣大的軟件開發(fā)行業(yè)。

美國航空航天局(NASA,以下皆用英文簡稱)有一套自己的編碼標準,以確保所有NASA應(yīng)用的代碼質(zhì)量和安全。這些標準漸漸演變適用于廣大的軟件開發(fā)行業(yè)。

代碼安全規(guī)則

JPL(噴氣推進實驗室)的***科學(xué)家Gerard J. Holzmann表示,甚至是關(guān)鍵應(yīng)用的代碼質(zhì)量也因為大量任意的規(guī)則和不一致的準則而受害。這也是為什么實驗室要發(fā)布編碼十誡來管轄所有NASA軟件的原因。

[[141315]]

Holzmann和團隊在設(shè)計這些軟件開發(fā)規(guī)則時,時刻謹記代碼的安全問題。該規(guī)則明確寫明是關(guān)于C語言的——C語言是NASA用于備份關(guān)鍵安全代碼的支柱語言,有著悠久的歷史和廣泛的工具支持。不過,這些也可應(yīng)用于其他大多數(shù)編程語言:

  • 限制所有代碼為簡單的控制流結(jié)構(gòu)——不使用goto語句,不使用setjmp和longjmp結(jié)構(gòu)以及直接或間接的遞歸。

  • 所有的循環(huán)必須有固定的上限。用檢查工具靜態(tài)地證明,預(yù)先設(shè)定的上限是一個循環(huán)不能超過的迭代次數(shù),在數(shù)學(xué)上是可能的。如果循環(huán)限制不能靜態(tài)證明,那么就違背了此條規(guī)則。

  • 初始化后不要使用動態(tài)內(nèi)存分配。

  • 一個函數(shù)在標準參考格式下——每個語句一行,每個聲明一行——得能印刷到同一張紙上。通常,這意味著每個函數(shù)的代碼不超過60行左右。

  • 代碼的斷言密度應(yīng)平均為至少每個函數(shù)有兩個斷言。斷言用于檢查異常情況,在現(xiàn)實執(zhí)行中是永遠不會發(fā)生的。斷言必須始終是無副作用的,并且被定義為 布爾測試。如果斷言失敗,那就應(yīng)該采取明確的恢復(fù)行動,例如,通過返回錯誤條件到執(zhí)行失敗斷言的函數(shù)的調(diào)用者。對于任何斷言,靜態(tài)檢查工具可以證明,它永 遠不會失敗或從未違背此條規(guī)則(即,不可能通過增加無益的“assert(true)”語句來滿足此條規(guī)則)。參見:《Developing NASA’s mission software with Java》

  • 數(shù)據(jù)對象必須在盡可能小的范圍內(nèi)聲明。

  • 非空函數(shù)的返回值必須由每個調(diào)用函數(shù)進行檢查,參數(shù)的有效性必須在每個函數(shù)內(nèi)部進行檢查。

  • 使用預(yù)處理器必須僅限于包含頭文件和簡單宏定義。標記粘貼,變量參數(shù)列表,以及遞歸宏調(diào)用是不允許的。所有宏必須擴展到完整的語法單位。條件編譯 指令的使用通常也是靠不住的,但無法始終避免。這意味著,我們不應(yīng)該超出標準樣板,即使在大型軟件開發(fā)中,也不應(yīng)該有超過一個或兩個條件編譯指令,并避免 多次包含相同的頭文件。每一次使用條件編譯指令都應(yīng)該有正當(dāng)理由,并在代碼中通過基于工具的檢查器標記。

  • 指針的使用應(yīng)當(dāng)受到限制。具體地講,解引用不允許超過一個級別。指針解引用操作可能無法隱藏在宏定義或內(nèi)部定義類型聲明。函數(shù)指針是不允許的。

  • 從開發(fā)的***天開始,所有代碼都必須進行編譯,并且所有的編譯器警告應(yīng)該在編譯器最嚴謹?shù)脑O(shè)置下開啟。所有代碼都必須在這些設(shè)置沒有任何警告下進行編譯。所有代碼每日至少必須經(jīng)過一臺靜態(tài)源代碼分析器檢查,當(dāng)然***能夠不止一臺,并在零警告下通過分析。

***,正如Holzmann解釋的那樣:

如果你覺得這些規(guī)則看上去過于苛刻,那么請不要忘記,這是在NASA,你的生命可能就取決于它的正確性:代碼要用來控制你飛的飛機,核能量與你住的地方可能只有幾英里,或攜帶宇航員送入軌道的航天器。

這些規(guī)則正是這一行業(yè)所需的數(shù)字安全帶——畢竟,生命之重重于泰山,否則將會帶來一場浩劫……

譯文鏈接:http://www.codeceo.com/article/nasa-10-coding-commandments.html
英文原文:NASA’s ten coding commandments

歡迎發(fā)表你的看法。

責(zé)任編輯:王雪燕 來源: 碼農(nóng)網(wǎng)
相關(guān)推薦

2015-11-03 10:01:07

美國航空航天局數(shù)據(jù)中心

2020-07-21 10:22:28

網(wǎng)絡(luò)安全黑客技術(shù)

2023-04-27 19:22:30

2009-02-04 08:41:16

谷歌NASA美國國家航空航天局

2011-03-31 10:22:41

Java開發(fā)

2024-12-25 15:07:43

2012-07-30 10:04:56

2015-12-15 14:38:12

2012-02-16 09:35:26

美國國家航空航天局NASA大型機

2024-12-25 16:13:41

2011-03-30 10:15:24

2015-12-25 11:34:25

2020-03-29 23:15:29

人工智能社交媒體AI

2010-12-28 09:53:39

2020-10-22 12:32:51

AI 衛(wèi)星人工智能

2020-04-28 14:40:02

云監(jiān)工直播火星

2014-06-16 16:13:08

2017-01-04 16:09:49

2018-01-31 10:31:09

OpenStack開源框架
點贊
收藏

51CTO技術(shù)棧公眾號