仿真在线:有限元分析咨询与培训中心——Ansys|Fluent|Abaqus|HFSS|SolidWorks|课程培训

【經驗分享】為追求100%可靠,NASA提出10條代碼編寫原則

2017-05-18  by:CAE仿真在線  來源:互聯網

【經驗分享】為追求100%可靠,NASA提出10條代碼編寫原則fluent分析案例圖片1

美國宇航局(National Aeronautics and Space Administration,縮寫為 NASA)是美國聯邦政府的一個獨立機構,負責制定、實施美國的民用太空計劃、與開展航空科學暨太空科學的研究。在太空計劃之外,美國國家航空航天局還進行長期的民用以及軍用航空航天研究。

在普通人的眼中,NASA是一個很“高級”的機構,其成員包含大量不同領域的科學家和研究人員。與其他任何組織機構類似,NASA的日常工作,以及所執行的幾乎全部項目也離不開計算機的輔助,出于需求的特殊性和重要性,他們所使用的很多計算機軟件都是內部自行開發的,在一些重要項目的關鍵領域發揮著作用。

去年,一位前NASA實習生把美國阿波羅登月項目的11號計算機 --- 阿波羅導航計算機 (Apollo Guidance Computer) 系統源代碼上傳到了 GitHub,此舉在開發者群體中引起了極大的熱議。

此外,NASA官方也已將自己的部分源代碼開源到GitHub,讓我們得以管窺這一頂尖科研機構內的聰明大腦們寫代碼的專業水平。

大型的復雜軟件項目通常會遵循一定的代碼編寫標準和指南。這些指南奠定了軟件開發過程中必須遵守的基本原則:

  1. 代碼的結構如何安排?

  2. 應不應當使用哪些語言特性?

出于效果的角度考慮,這些原則必須盡可能精簡并且必須足夠具體,這樣才能更好地被人理解并記憶。

本文將介紹由NASA噴氣推進實驗室首席科學家Gerard J. Holzmann所提出的,側重于安全參數的10條代碼編寫原則。當然,這些原則也適用于其他編程語言。

為NASA工作的全球頂尖程序員在編寫高度安全的代碼時就沿襲了這樣的一套指南。實際上,很多組織,包括NASA噴氣推進實驗室主要會選擇使用C語言編寫代碼。

原因在于這種語言具備完善的工具支持,包括邏輯模型分離器、調試器、靜態編譯器、源代碼分析器,以及度量工具等。

有時候,編寫代碼必須遵守一定的原則,尤其是在代碼的正確性會對人的生命產生決定性影響的領域,例如飛機、將宇航員送上同步軌道的航天器,以及距離居住地僅幾英里遠的核電站等設施運行的控制代碼。

原則1 – 簡化控制流程


使用盡可能精簡的控制流程構造編寫程序 – 不要使用setjmp或longjmp構造、goto語句,以及直接或間接的recursion。

原因:簡化控制流程有助于提高代碼清晰度,增強代碼可驗證能力。不使用遞歸,便不會產生循環的函數調用圖,這樣也可證明所有本應有界的執行實際上都是有界的。

原則2 – 為循環設置上限次數


所有循環必須有固定次數的上限。我們可以通過驗證工具靜態地證明,為循環中迭代數量所設立的上限次數未被超越。

如果無法以靜態方式對循環的次數界限加以證明,則可認為未遵守該原則。

原因:為循環設置次數界限,避免使用遞歸,這些做法有助于預防代碼失控。然而該原則無法適用于本就不應終止的迭代(例如進程調度器)。此時將沿用該原則的逆向原則:必須能夠靜態地證明迭代不能終止。

原則3 – 不使用動態內存分配


不要在初始化完成后進行動態內存分配。

原因:諸如malloc等內存分配機制,以及垃圾回收器通常會產生無法預知的行為,進而可能會對性能產生影響。更重要的是,還有可能因為程序員的失誤造成內存錯誤,例如:

  • 試圖分配超過可用物理內存數的內存

  • 忘記釋放內存

  • 繼續使用已被釋放的內存

  • 對已分配內存進行越界使用

應強制所有模塊位于固定大小、預先分配的存儲區域中,借此可避免此類問題,并簡化內存使用情況的驗證工作。

堆中未分配內存的情況下,動態請求內存的唯一方式是使用棧內存。

原則4 – 不使用冗長的函數


任何函數的長度不應超過使用標準參考格式(每個聲明最多一行,每個語句最多一行)打印的紙張上一頁紙所能容納的字符數。這意味著函數的代碼不應超過60行。

原因:過長的函數通常意味著結構并非最優。每個函數都應是可理解且可驗證的單一邏輯單位。如果在計算機顯示器上需要多屏界面才能完整顯示,這樣的邏輯單位通常會極難理解。

原則5 – 低斷言密度


【經驗分享】為追求100%可靠,NASA提出10條代碼編寫原則fluent分析案例圖片2

程序的斷言密度(Assertion density)應平均保持為每個函數最少兩個斷言。斷言可用于檢查現實運行過程中本絕不應出現的異常狀況,因此應定義為Boolean測試。當斷言失敗后,應執行明確的恢復操作。

如果靜態檢查工具證明斷言絕對不會Fail或Hold,則可認為未遵守該原則。

原因:業界的代碼編寫工作統計報告顯示,通過單元測試可發現,通常我們所編寫的每10-100行代碼中至少會存在一處缺陷。隨著斷言密度的增高,攔截缺陷的機會也會增大。

斷言的另一個重要之處在于,它是防御性編程(Defensive coding)策略的重要組成部分。我們可以使用斷言驗證函數執行前后的狀況,函數的執行參數和返回值,以及循環不變式(Loop-invariant)。在完成性能關鍵代碼的測試工作后,可將斷言選擇性地禁用。

原則6 – 以最小范圍級別聲明數據對象


該原則同時也是數據隱蔽(Data hiding)的基本原則。所有數據對象均必須以盡可能最小的范圍級別進行聲明。

原因:如果某對象不在范圍內,意味著其值將無法引用或已損壞。該原則不鼓勵出于多種可能導致故障診斷工作變得更復雜的互斥意圖重用變量。

原則7 – 檢查參數和返回值


應在每次調用函數后檢查非空函數的返回值,并應在每個函數內部檢查參數的合法性。

在最嚴格的形式下,該原則意味著就算printf語句和文件close語句的返回值也應進行檢查。

原因:如果對一個錯誤結果的響應與對成功結果的響應本不應有任何區別,那么很明顯需要檢查返回值。通常對close和printf的調用便符合這種情況。此時一種可行的方法是將函數的返回值明確拋出給void,這意味著開發者明確(而非意外地)決定忽略該返回值。

原則8 – 限制預處理程序的使用


預處理程序(Preprocessor)應僅限用于頭文件和宏定義。遞歸的宏調用、令牌傳遞,以及變量參數列表均不允許使用。就算大型應用程序開發工作中,標準樣板文件(Boilerplate)之外也可能有必要使用一兩個以上的條件編譯指令,這是為了避免將同一個頭文件包含多次。每個這種用法必須通過工具檢查器添加標記,并通過代碼闡述原因。

原因:C語言預處理程序是一個強大但較為含糊的工具,有可能徹底破壞代碼的清晰度,并讓很多基于文本的檢查器產生混淆。就算具備正式的語言定義,包含無界限預處理程序代碼的構造也會顯得非常難以解讀。

有關條件編譯的注意事項同樣很重要 – 就算只使用10個條件編譯指令,代碼也有會產生1024(2^10)個可能的版本,這會導致測試工作量劇增。

原則9 – 限制指針的使用


指針的使用必須加以限制。通常只允許不超過一層的解引用(Dereferencing)。指針解引用操作不應隱藏在typedef聲明或宏定義內部。此外函數指針也是不允許使用的。

原因:指針很容易被濫用,就算專家也難以徹底避免。指針的存在會使得我們難以跟蹤或分析程序中數據的流動,尤其是在使用基于工具的靜態分析器執行這些操作時。函數指針還會對靜態分析器所能執行的檢查類型產生限制,因此除非有非常必要的理由,否則一般不推薦使用。如果使用函數指針,通常幾乎將無法通過工具證明遞歸的缺席,此時只能提供其他方法彌補這種分析能力的缺失。

原則10 – 編譯所有代碼


從開發工作第一天開始時,就必須對所有代碼進行編譯。必須啟用編譯器的警告功能,并使用最細致的檢查選項。代碼必須能通過這樣的設置在不產生任何警報的情況下順利編譯完成。

所有代碼必須每天一次,使用至少一種(多種則更好)最新型的靜態源代碼分析器進行檢查,并且必須順利通過分析器的整個檢查過程而不產生任何警告。

原因:市面上有很多效果卓越的源代碼分析器,其中很多甚至是以免費軟件的形式發布的。對于這樣可以直接使用的現成技術,任何軟件開發工作都沒理由不加以充分利用。

如果編譯器或靜態分析器遇到問題,導致問題/錯誤的代碼必須重寫,這樣才能進一步改善代碼質量。

NASA對這些原則的看法為:“這些原則就如同汽車安全帶,也許一開始會覺得有些不舒適,但很快會變成每個人的第二本能,到時候很難想象會有人不這么做。”

此文在Reddit引發了熱烈的討論,現將部分有價值內容摘錄如下:

@fluffynukeit:本文的很多原則提到使用靜態代碼分析器進行分析是一種更簡單可靠的辦法。如果我在開發C或C++代碼,有什么好用的免費靜態代碼分析器嗎?一方面我想看看這些分析器的工作效果,另一方面,我一直在使用另一個極為糟糕的分析器,想對比一下來了解原本使用的分析器到底有多糟糕。

@tobascodagama:我覺得有必要提醒大家,本文所說的“安全關鍵程序”是一種面向特定領域的術語。每次網上流傳類似這樣的東西時,大家都會試圖將相關內容應用在一般常規用途的軟件中,但實際上除非你的軟件中出現的無法處理的異常真的會致命,否則并不需要如此嚴格(也許也不應該這樣做,因為大部分此類原則會在代碼可讀性和可維護性方面造成不小的麻煩)。

@xianbaun:原則3 – 不使用動態內存分配,這條讓我大吃一驚。我很好奇,如果不使用動態內存分配,你到底如何編寫哪怕很小規模的程序!是否就只在程序運行時分配一大塊內存,隨后程序的所有執行都在這塊內存中進行?

@aim2free:我倒是對于NASA使用C語言感覺驚訝,我本想著他們會使用Ada之類的東西。 這些原則中很多原則與我在ASEA(現ABB)擔任開發者時所遵守的原則是相同的,拋開這些不談,同時拋開有關預處理程序的原則不談,我們當時主要使用Pascal,對于遞歸函數也制訂了相應的原則。我編寫了一個預處理程序,這樣就可以保證開發者能夠獲得恰當的聲明,而無需擔心這些問題,此外我們還會按照標準設置程序代碼的縮進和格式,畢竟每個程序員在代碼格式方面都有一些個人偏好。所有程序都有必要在這些問題方面由其他程序員進行交叉檢查。

@NewYorkCityGent:他們為什么不把這些原則強制應用到編譯器中?可以通過 -WNasa 或其他類似的東西告訴開發者是否違反了這些原則。此外還需要使用 std lib C 來維護這些嚴格的原則。 建議挺好,就是不明白為什么不用自動化的方法來應用(或者他們正是這樣做的?)

你有什么想法或者想說的,歡迎評論區留言討論。另外,本文為翻譯文章,有表述不妥之處,還請指正。原文鏈接:

http://www.rankred.com/nasa-coding-rules/

作者|RankRed 編輯|大愚若智
-------------------免責申明---------------------

本著學習交流的目的,自公眾號聊聊架構轉載該文,如有不適,請聯系kf#1cae.com(請用@代替#)進行處理,謝謝理解與支持



開放分享:優質有限元技術文章,助你自學成才

相關標簽搜索:【經驗分享】為追求100%可靠,NASA提出10條代碼編寫原則 Fluent培訓 Fluent流體培訓 Fluent軟件培訓 fluent技術教程 fluent在線視頻教程 fluent資料下載 fluent分析理論 fluent化學反應 fluent軟件下載 UDF編程代做 Fluent、CFX流體分析 HFSS電磁分析 

編輯
在線報名:
  • 客服在線請直接聯系我們的客服,您也可以通過下面的方式進行在線報名,我們會及時給您回復電話,謝謝!
驗證碼

全國服務熱線

1358-032-9919

廣州公司:
廣州市環市中路306號金鷹大廈3800
電話:13580329919
          135-8032-9919
培訓QQ咨詢:點擊咨詢 點擊咨詢
項目QQ咨詢:點擊咨詢
email:kf@1cae.com




主站蜘蛛池模板: 南通搬运公司|吊车租赁|大件吊装|设备搬运|工厂搬迁|起重吊装搬运-顺林搬运 | 上饶市安信永辰会计师事务所有限公司 | 西安测试仪-西安电压测试仪-西安电流测试仪-西安热油汽水测试仪-西安阻抗测试仪-西安时间速度测试仪-西安电力设备厂家-西安中洲电力设备有限公司 | 实验室装修设计-实验室工程建设-实验室实验台通风柜-瑞斯达实验室系统设备(苏州)有限公司 | 上海商标注册,上海注册商标,上海商标代理,国际商标注册,版权登记-上海律点知识产权代理有限公司 上海山田机械有限公司 | 偏光显微镜-金相抛光机|预磨机|磨抛机|镶嵌机|切割机-上海蔡康光学仪器厂 | 洗地机_扫地机_扫地车品牌_尘推车_工业吸尘器_山东鼎洁盛世 | 泰州光明会计师事务所有限公司-财务业务审计,会计服务业务及资产评估业务的专业服务机构 | 湖州网站建设_湖州网络公司_湖州后普网络科技有限公司 | 英格索兰空压机_英格索兰空压机配件_英格索兰空压机维修—商天机械 | 西安网站建设,西安网站设计制作,西安短视频拍摄_短视频运营就选动力无限网络推广公司 | 注塑加工,无锡塑料件加工,注塑模具加工厂家-无锡富立康精密模塑有限公司 | 威海保温板,威海泡沫,威海EPS,威海EPP-威海东兴泡塑科技有限公司 | 油漆颜料砂磨机,油墨水砂磨机,水性涂料砂磨机-常州市奥能达机械设备有限公司 | 网络舆情_网络舆情监控系统_舆情监测软件_舆情监控平台-北鲲舆情 | 皮带输送机-宁津县浩发链条有限公司| 数字多媒体展厅设计,智慧科技互动企业展馆展厅设计公司-深圳炫之风 | 消防烟感清洗,火灾探测器清洗,探测器清洗厂家 | 九九信息网-专业的分类信息网站 九江中澳钽铌有限公司 | 精密齿轮,同步带轮,蜗轮,蜗杆,减速机齿轮,行星齿轮-和兴齿轮 | 消防水电施工,消防水电安装,消防水电施工公司,消防水电改造-亿杰北京消防工程公司 | 饮料瓶-白酒瓶-绿色玻璃瓶-山东玻璃瓶厂家-枣庄市金泰玻璃有限公司 | 陕西锐锋建筑安装有限公司,锐锋建筑,总承包,专业分包,市政综合,劳务,水电钢构,铁路公路,房建,房屋建筑施工 | 济南货架|济南仓储货架|济南仓库货架|山东蕴达金属制品有限公司 济南海纳特科技有限公司 | 秦皇岛天视影像有限公司,宣传片创意拍摄制作,商业广告拍摄公司,影视影像服务商 - 秦皇岛天视影像有限公司,宣传片创意拍摄制作,商业广告拍摄公司,影视影像服务商 秦皇岛市信恒电子科技有限公司 秦皇岛市华谊彩印有限公司 | 妙手官网—商品管理、批量修改、订单处理、营销水印 | 真空热处理-渗碳热处理-氮化热处理-[东莞德亿]专业热处理加工厂家 | 太原铁艺围栏-山西泓宸辉铁艺工程有限公司 | 威学一百-专注国际学校择校备考-DSE-A-level-雅思-托福-OSSD-港澳台联考-AP-IGCSE-IB-AMC-多邻国-PTE-SAT-SSAT-小语种(如日语,韩语,德语,法语,西班牙语,意大利语,俄语,泰语)等考试培训,为出国留学学生提供个性化定制性学习方案,线下实体面授+线上网络课程, 提供一对一,小班课等多种班型 | 华帝衣柜定制_全屋家具定制_橱柜定制-华帝家居 | 商用车之家——观点有态度 热点不缺席 靠谱的商用车门户网站 | 江西省屹诚建筑装饰工程有限公司| 小地磅,钢瓶秤,叉车称,轮椅秤,倒桶秤,畜牧秤,轴重仪,称重模块——上海实干实业有限公司-网站首页 | 山东装卸登车桥_液压装卸升降平台_固定|移动登车桥_山东牛斗重工厂家 | 合肥年会策划-合肥开业庆典公司-合肥会务活动礼仪公司-合肥展台搭建/音响租赁公司 [七色海] | 球场地板_运动场地面_体育设施器材_地坪漆工程_项目承接-大上实业(深圳)有限公司 | 木别墅-小木屋-防腐木木屋-成都腾龙装配式建筑科技有限公司 | 磨粉设备_雷蒙磨粉机_雷蒙超细磨| 呼吸家官网|肺功能检测仪生产厂家|国产肺功能仪知名品牌|肺功能检测仪|肺功能测试仪|婴幼儿肺功能仪|弥散残气肺功能仪|肺功能测试系统|广州红象医疗科技有限公司|便携式肺功能仪|大肺功能仪|呼吸康复一体机|儿童肺功能仪|肺活量计|医用简易肺功能仪|呼吸康复系统|肺功能仪|弥散肺功能仪(大肺)|便携式肺功能检测仪|肺康复|呼吸肌力测定肺功能仪|肺功能测定仪|呼吸神经肌肉刺激仪|便携式肺功能 | 郑州长城冶金设备有限公司| 连云港海盛石英科技有限公司|