當前位置:首頁 > 嵌入式 > 嵌入式分享
[導讀]幾乎我見過的每一個程序員都想寫一個堅如磐石的軟件。你對自己的發(fā)展感到驕傲,如果你的工作是編寫軟件,你希望軟件能夠運行。我從來沒有見過任何人在項目開始時說過,"讓我們寫出人類所知道的最糟糕的,緊密耦合的,昂貴的代碼。我們都想編寫好的代碼,使我們的產(chǎn)品無縫地工作,并贏得我們的贊揚,或至少我們的老板。不幸的是,編寫嵌入式軟件往往會變成一個充滿了bug、漏洞和其他令人毛骨悚然的東西的泥沼。所以,讓我們打破鏈條吧!這篇文章將討論構(gòu)建堅固的嵌入式軟件的五個基本技巧和技巧,我發(fā)現(xiàn)這些技巧和技巧有利于我的客戶、同事、學生、我自己,希望還有你。

幾乎我見過的每一個程序員都想寫一個堅如磐石的軟件。你對自己的發(fā)展感到驕傲,如果你的工作是編寫軟件,你希望軟件能夠運行。我從來沒有見過任何人在項目開始時說過,"讓我們寫出人類所知道的最糟糕的,緊密耦合的,昂貴的代碼"。我們都想編寫好的代碼,使我們的產(chǎn)品無縫地工作,并贏得我們的贊揚,或至少我們的老板。不幸的是,編寫嵌入式軟件往往會變成一個充滿了bug、漏洞和其他令人毛骨悚然的東西的泥沼。所以,讓我們打破鏈條吧!這篇文章將討論構(gòu)建堅固的嵌入式軟件的五個基本技巧和技巧,我發(fā)現(xiàn)這些技巧和技巧有利于我的客戶、同事、學生、我自己,希望還有你。

技巧1--讓你的產(chǎn)品及早且經(jīng)常地落入客戶的手中。

你可能會想知道什么東西能讓你的客戶提前拿到產(chǎn)品,并且經(jīng)常與堅固的嵌入式軟件有關(guān)。最后,你的客戶會決定你的產(chǎn)品是否堅固。如果你在沒有你的客戶的情況下,把你所有令人敬畏的、優(yōu)雅的、改變世界的代碼寫在一個倉庫里,你將會被一個突然的覺醒。

現(xiàn)在許多團隊開始在沒有實際需求的情況下開發(fā)他們的產(chǎn)品。消費者通常不知道他們想要什么,直到他們觸摸、感覺和玩一種產(chǎn)品。因此,如果開發(fā)人員不與客戶密切合作,他們就可以隨意或構(gòu)建他們認為客戶需要的東西。即使一個團隊足夠幸運地擁有需求,這并不意味著客戶實際上知道他們想要什么。他們常常以為自己知道,但經(jīng)常改變主意。我不知道你怎么樣,但是盡管我有很高的學位和勤奮的工作,客戶還是經(jīng)常給我驚喜。獲得客戶反饋是至關(guān)重要的,我知道這聽起來很靈活,但也許那些家伙畢竟在做什么。

在我早期的咨詢生涯中,我有一個發(fā)展了月球屋頂?shù)目蛻簟K麄冃枰獛椭到y(tǒng)測試他們的產(chǎn)品,以確保他們的固件充分工作。一個驕傲的工程師把他們的原型帶出來,給我看了所有的鐘和口哨,以及它的偉大性。作為顧客,我做的第一件事就是同時按兩個按鈕。系統(tǒng)失控了。在震驚的表情變成憤怒之后,他問:"誰會同時按兩個按鈕?""。顯然,我和任何其他惡作劇的顧客,想知道如果我同時按下這兩個按鈕會發(fā)生什么!你只是不知道什么或如何使用一個產(chǎn)品,直到客戶,不設計它的人,掌握它。

技巧2-利用和使用現(xiàn)代測試技術(shù)

構(gòu)建堅固的軟件的關(guān)鍵是利用現(xiàn)代測試技術(shù)來提高代碼的健壯性。在當今的行業(yè)中,人們正在大力推動嵌入式團隊采用開發(fā)計劃和CI/CD等工具。這些方法和工具能夠在小型單元(單元測試)、多個模塊(集成測試)和系統(tǒng)一級(系統(tǒng)測試)中測試軟件,以及許多其他可能的測試。測試使團隊能夠在特定的、受控制的條件下發(fā)現(xiàn)他們的軟件存在的問題。結(jié)果是一個更加健壯的軟件系統(tǒng)!

埃德斯格·迪杰斯特拉曾經(jīng)說過:"測試只能證明存在錯誤,而不能證明沒有錯誤。"明智的智慧應該提醒你,構(gòu)建健壯的軟件不僅需要測試。采用單元測試和CI/CD可以很有吸引力地顯示您有100%的代碼覆蓋,您的系統(tǒng)是堅固的。不幸的是,這種想法是個陷阱!是的,您必須采用現(xiàn)代測試技術(shù)來提高您的代碼質(zhì)量,測試您的系統(tǒng),并提高其健壯性。然而,您還需要采取額外的行動,例如執(zhí)行代碼評審、利用對編程、體系結(jié)構(gòu)性能和分析、度量監(jiān)控等等。

技巧3-應用靜態(tài)代碼分析工具來識別潛在的錯誤

嵌入式軟件開發(fā)人員日常使用的編程語言通常沒有完全指定。有些構(gòu)造或行為沒有在語言標準中定義,而是編譯器定義的行為。例如,如果讓一個整數(shù)循環(huán)在C中滾動,會發(fā)生什么情況?你能得到什么價值?這取決于編譯器,因為C標準沒有告訴你,所以編譯器供應商決定了最佳的行動方案。

靜態(tài)代碼分析是一個您必須利用的工具,以具有健壯的固件。靜態(tài)分析將幫助您識別代碼中的潛在錯誤。靜態(tài)分析可以指出不推薦的特定構(gòu)造,檢查代碼是否符合編碼標準,檢測漏洞,并提供代碼度量,僅舉幾個例子。我無法計算靜態(tài)分析工具在我的代碼出現(xiàn)潛在問題時,或在我允許復雜性進入野草時,抓住它的頻率。我無法強調(diào)設置靜態(tài)分析工具并將其納入正常的日常編碼和開發(fā)流程的重要性。

技巧4-使用代碼分析工具來識別和優(yōu)化性能瓶頸

當您考慮堅如磐石的嵌入式軟件時,您可能會考慮滿足客戶需求和沒有bug的軟件。然而,一個經(jīng)常被忽視的基本組成部分是系統(tǒng)的最佳運行。響應性可能和系統(tǒng)不崩潰或一些丑陋的錯誤抬頭一樣重要。我非常喜歡使用分析工具來監(jiān)控和優(yōu)化產(chǎn)品的性能。有時候我做了一個簡單的代碼更改,大大提高了CPU的利用率。

分析工具可以幫助您檢查任務的周期性、執(zhí)行時間、狀態(tài)機行為、內(nèi)部通信性能等等。你需要使用工具來幫助你想象你的系統(tǒng)的性能,并抓住那些讓你頭疼的小問題。你不能依靠人類系統(tǒng)的監(jiān)控來說它是正確的。我不想說,但是我們無法捕捉和監(jiān)控我們的工具所能做到的一切!(至少不是實時的)。

技巧5-結(jié)合防御性編程技術(shù)來處理意外的輸入和場景

你可能是一個好的程序員或者管理者,在他們的團隊中有好的程序員。然而,在所有的嵌入式系統(tǒng)代碼中,我仍然發(fā)現(xiàn)團隊錯過的最少的成果之一是驗證他們的輸入和輸出。我知道,它是編程101的東西。然而,它似乎被許多開發(fā)人員忽略了。我不確定開發(fā)人員是不是太專注于編寫盡可能少的代碼行,還是覺得驗證在某種程度上膨脹了他們的代碼。如果您想編寫堅如磐石的嵌入式軟件,您必須使用基本的防御性編程技術(shù)來處理您可能無法預料的意外輸入和場景。

一個簡單的例子可能是檢查函數(shù)中接收的參數(shù)是否在預期范圍之內(nèi)。另一種可能是假設內(nèi)存損壞可能在循環(huán)中發(fā)生,并將其等于值(==在C++中)改變?yōu)橐粋€比或大的等號(&tt;=)。健壯的軟件并不是通過宏偉的建筑細節(jié)或巧妙、優(yōu)雅的代碼編寫來實現(xiàn)的。相反,它是通過謹慎和近乎偏執(zhí)地管理代碼的逐行細節(jié)來實現(xiàn)的。

結(jié)論

我們都想編寫可靠的高質(zhì)量軟件。不幸的是,今天的大部分軟件都離它很遠。別誤會,我想情況在改善,但我們還有很長的路要走。我們已經(jīng)探索了五個關(guān)鍵的技巧,希望你們本周能仔細考慮。您是否在您的開發(fā)過程中使用了其中的每一個?你在注意細節(jié)嗎?你的客戶能提前拿到你的產(chǎn)品嗎?你會發(fā)現(xiàn),問自己幾個簡單的問題,關(guān)于這些小貼士,你會發(fā)現(xiàn)你需要做的調(diào)整,以開始編寫和提供更堅實的嵌入式軟件


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉