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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

硬件工程師應(yīng)牢記嵌入式系統(tǒng)設(shè)計(jì)的10個(gè)技巧

STM32嵌入式開發(fā) ? 來源:STM32嵌入式開發(fā) ? 2023-05-23 11:46 ? 次閱讀

嵌入式系統(tǒng)設(shè)計(jì)不僅需要了解硬件,還需了解軟件是如何影響硬件并與硬件進(jìn)行交互的。設(shè)計(jì)硬件所需的范式可能與設(shè)計(jì)軟件完全相反。當(dāng)從硬件設(shè)計(jì)轉(zhuǎn)向包含軟件的設(shè)計(jì)時(shí),硬件工程師應(yīng)牢記以下十個(gè)技巧。

技巧#1:流程圖第一,實(shí)現(xiàn)第二

當(dāng)工程師首次邁入軟件開發(fā)領(lǐng)域時(shí),會(huì)有一種強(qiáng)烈的誘惑力促使他們立刻投入工作并開始寫代碼。這種做法就好比在電路邏輯圖還未完成前就試圖設(shè)計(jì)印刷電路板(PCB)。在著手開發(fā)軟件時(shí),抑制一上來就想寫代碼的沖動(dòng)至關(guān)重要,應(yīng)首先用流程圖制定一個(gè)軟件架構(gòu)圖。這樣的方法會(huì)使開發(fā)人員對(duì)應(yīng)用所需的不同部分與組件形成一個(gè)概念,就像電路邏輯圖可以告訴工程師需要哪些硬件元件一樣。這樣可確保程序整體建立在良好的組織和深思熟慮之上,減少程序調(diào)試時(shí)間,從長期看,這樣做還可以節(jié)省時(shí)間、省去麻煩。

技巧#2:使用狀態(tài)機(jī)控制程序流程

狀態(tài)機(jī)是20世紀(jì)最偉大的軟件發(fā)明之一。一個(gè)應(yīng)用程序往往可被分為多個(gè)狀態(tài)機(jī),每個(gè)狀態(tài)機(jī)都控制該應(yīng)用程序的特定部分。這些狀態(tài)機(jī)都擁有自己的內(nèi)部狀態(tài)和狀態(tài)轉(zhuǎn)換,從中可看出軟件如何與各種激勵(lì)相互作用。用狀態(tài)機(jī)來設(shè)計(jì)軟件,可簡化軟件的開發(fā),使之模塊化、可維護(hù),并易于理解。現(xiàn)在已經(jīng)有多種資源來演示狀態(tài)機(jī)理論和算法。

技巧#3:避免使用全局變量

在函數(shù)式編程的年代,函數(shù)要先于形式,程序員的唯一目標(biāo)是盡可能地讓程序按預(yù)期方式快速運(yùn)行,而不用考慮程序結(jié)構(gòu)或可重用性。這種編程范式會(huì)毫無顧慮地使用全局性變量,程序中的任何函數(shù)都可能修改它。其結(jié)果就造成了變量被破壞的幾率增加或變量被誤用。在新推薦的面向?qū)ο蟮姆妒街?,?yīng)在最小的范圍內(nèi)定義變量并封裝它們,以防止其他函數(shù)的誤用或破壞。因此,建議限制使用全局變量的數(shù)量。在C語言中可用外部關(guān)鍵字標(biāo)識(shí)這些變量。

技巧#4:充分利用模塊化特性

無論問哪一名工程師,項(xiàng)目的哪部分最有可能延遲交付并超出預(yù)算,答案都是軟件。軟件往往是復(fù)雜的,且難以開發(fā)和維護(hù),尤其是當(dāng)整個(gè)應(yīng)用都存在于單個(gè)文件或松散關(guān)聯(lián)的多個(gè)文件中時(shí)。為了改善可維護(hù)性、可重用性及復(fù)雜性,強(qiáng)烈建議程序員充分利用現(xiàn)代編程語言的模塊化特性,將常用功能分解成模塊。以這樣的方式分解代碼,程序員就能著手建立函數(shù)與特性庫,然后在一個(gè)接一個(gè)的應(yīng)用中重用它們,從而通過連續(xù)測試而改善代碼質(zhì)量,同時(shí)也減少了開發(fā)時(shí)間,降低了開發(fā)成本。

技巧#5:保持中斷服務(wù)例程的簡單性

中斷服務(wù)例程用來中斷處理器對(duì)當(dāng)前代碼的執(zhí)行,而去處理剛剛觸發(fā)中斷的外圍設(shè)備。無論何時(shí)執(zhí)行中斷,都需要一定的開銷,用于保存當(dāng)前程序的狀態(tài)并運(yùn)行中斷,然后將處理器回歸原程序狀態(tài)。現(xiàn)代處理器要比多年前的處理器快得多,但仍需要考慮此花銷。一般情況下,程序員都想把中斷運(yùn)行時(shí)間降至最低,以避免干擾主代碼。這意味著中斷應(yīng)該短而簡單。中斷中不應(yīng)調(diào)用函數(shù)。此外,如果中斷變得過于復(fù)雜或耗時(shí),那么就應(yīng)該只在必要時(shí)利用中斷做最少量的工作,例如,將數(shù)據(jù)載入緩沖區(qū)并設(shè)置一個(gè)標(biāo)志,然后讓主代碼處理輸入的數(shù)據(jù)。這樣做可保證大多數(shù)處理器的時(shí)間用于運(yùn)行應(yīng)用,而不是處理中斷。

技巧#6:使用處理器示例代碼進(jìn)行測試

設(shè)計(jì)硬件時(shí),構(gòu)建原型測試電路總是有益的,這樣可確保工程師對(duì)電路有正確的理解,然后再做電路板布局。這在設(shè)計(jì)軟件時(shí)也同樣適用。硅片制造商通常都有示例代碼,可用來測試微處理器的各個(gè)部分,這樣工程師們就可判定該部分的工作情況。此方法使人們明確知道應(yīng)該如何設(shè)計(jì)軟件體系架構(gòu),以及可能碰到的任何問題。在設(shè)計(jì)初期了解可能存在的障礙,比在產(chǎn)品交付前的最后幾小時(shí)才發(fā)現(xiàn)它們要好得多。這是預(yù)先測試一段代碼的好方法,但需提醒的是,制造商代碼往往不是模塊化的,要經(jīng)過徹底的修改才可用于實(shí)際應(yīng)用。隨著技術(shù)的進(jìn)步,也許某一天芯片供應(yīng)商會(huì)提供可用于生產(chǎn)的代碼。

技巧#7:限制功能復(fù)雜度

工程學(xué)中有一個(gè)舊詞叫“KISS”——保持簡單和直接。無論在處理何種復(fù)雜的工作時(shí),最簡單的方法就是把它分解為更小、更簡單、更易處理的任務(wù)。隨著工作或功能變得越來越復(fù)雜,人們要準(zhǔn)確無誤地記錄所有的細(xì)節(jié)也變得更困難。在寫一個(gè)函數(shù)時(shí),其復(fù)雜度在當(dāng)時(shí)看似適中,然而還必須考慮到,6個(gè)月后當(dāng)工程師進(jìn)行維護(hù)時(shí),還需要查看代碼。測量函數(shù)復(fù)雜度(如循環(huán)復(fù)雜度)的方法很多,現(xiàn)在已經(jīng)有工具可以自動(dòng)計(jì)算某個(gè)函數(shù)的循環(huán)復(fù)雜度。由經(jīng)驗(yàn)可知,函數(shù)的循環(huán)復(fù)雜度保持在10以下是最理想的。 無論在處理何種復(fù)雜工作時(shí),最簡單的方法就是把它分解為更易處理的任務(wù)。

技巧#8:使用源代碼存儲(chǔ)庫并頻繁提交代碼

人都是會(huì)犯錯(cuò)誤的,寫代碼時(shí)也會(huì)犯錯(cuò)。這就是為什么開發(fā)人員使用源代碼存儲(chǔ)庫是如此重要。源代碼存儲(chǔ)庫可使開發(fā)人員“存入”一個(gè)好的代碼版本,并描述對(duì)該基礎(chǔ)代碼所做的修改。這不僅使開發(fā)人員可以復(fù)原或追溯到的舊版代碼,還可以比較舊版代碼之間的不同。如果開發(fā)人員做的一系列修改破壞了系統(tǒng),只需點(diǎn)擊一下即可恢復(fù)好代碼版本!請(qǐng)謹(jǐn)記,如果不頻繁提交代碼,存儲(chǔ)庫就不會(huì)達(dá)到預(yù)期目的。如果做了不可修復(fù)的改變,過兩周才提交代碼再恢復(fù)的話,就會(huì)造成大量工作和時(shí)間的損失!

技巧#9:代碼注釋

在緊張的軟件開發(fā)中,開發(fā)人員很容易把注意力集中在編寫和調(diào)試代碼上,而忽略做詳細(xì)的注釋。在壓力之下,注釋工作往往拖到最后,因?yàn)殚_發(fā)人員認(rèn)為這是最后的一件事。然而,趁代碼在你腦中記憶猶新時(shí)就做注釋是至關(guān)重要的,這樣做可使其他開發(fā)人員或以后你自己讀懂注釋,理解代碼是如何工作的。

技巧#10:使用Agile開發(fā)流程

無論做何種類型的工程設(shè)計(jì),都建議先設(shè)定并遵守某種流程,以便質(zhì)量和成本都保持穩(wěn)定的并能按時(shí)交付。軟件開發(fā)人員已成功使用Agile開發(fā)流程開發(fā)高質(zhì)量軟件,這一流程可按任務(wù)的優(yōu)先順序做開發(fā)。優(yōu)先級(jí)別最高的任務(wù)在指定的時(shí)間內(nèi)首先完成,這被稱為迭代。這種方法的好處是可以使軟件開發(fā)流程保持順暢,還可以根據(jù)結(jié)果和客戶的需要,使需求和任務(wù)適應(yīng)每一次迭代并做相應(yīng)的修改。 網(wǎng)友評(píng)論 @ DickB 我不支持關(guān)于中斷程序的建議。在使用德州儀器TIMSP430低功耗微控制器時(shí),主代碼經(jīng)常只用于將處理器置于睡眠狀態(tài)。當(dāng)處理器處于激活狀態(tài)時(shí),所有工作都在中斷程序中完成。 @ The Real Dr Bob 從我的經(jīng)驗(yàn)看,也許這篇文章的標(biāo)題應(yīng)為“軟件工程師的10大技巧”。 我在面試一名軟件工程師時(shí)曾問過這樣一個(gè)問題:如何為一個(gè)新項(xiàng)目寫軟件? 回答是:著手寫軟件代碼! 我以為他會(huì)說“先閱讀規(guī)范,然后將軟件分解成小模塊并為它們?cè)O(shè)計(jì)流程圖”之類的話。 當(dāng)然,我沒錄用他。 @ Thinking_J 一切都很好。 但我還想增加一條:讓管理層學(xué)習(xí)Agile。 最重要的是,在項(xiàng)目的開始階段就為項(xiàng)目的完成設(shè)定一個(gè)現(xiàn)實(shí)的目標(biāo)(這是反復(fù)強(qiáng)調(diào)的)。而且,項(xiàng)目一開始就應(yīng)安排好適當(dāng)?shù)娜肆土鞒?,而不是后來才補(bǔ)上。

編輯:黃飛

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式系統(tǒng)
    +關(guān)注

    關(guān)注

    40

    文章

    3520

    瀏覽量

    128810
  • 狀態(tài)機(jī)
    +關(guān)注

    關(guān)注

    2

    文章

    489

    瀏覽量

    27395
  • 硬件工程師
    +關(guān)注

    關(guān)注

    175

    文章

    354

    瀏覽量

    74878

原文標(biāo)題:硬件工程師應(yīng)記住的10大軟件技巧

文章出處:【微信號(hào):c-stm32,微信公眾號(hào):STM32嵌入式開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式軟件工程師硬件工程師的區(qū)別?

    嵌入式軟件工程師硬件工程師的區(qū)別? 嵌入式軟件工程師 嵌入
    發(fā)表于 05-16 11:00

    嵌入式工程師比普通軟件工程師好在哪里?

    由于嵌入式主要分為操作系統(tǒng)硬件個(gè)方面,所以嵌入式工程師的就業(yè)方向要比一般的軟件
    發(fā)表于 11-20 15:37

    “八一八”嵌入式系統(tǒng)設(shè)計(jì)工程師那點(diǎn)事情

    ,工業(yè)控制等專用設(shè)備,和移動(dòng)通訊設(shè)備結(jié)合、GPS、娛樂相結(jié)合,嵌入式系統(tǒng)同樣可以發(fā)揮巨大的作用。嵌入式工程師嵌入式
    發(fā)表于 12-10 10:36

    嵌入式工程師的具體工作是什么?

    由于嵌入式主要分為操作系統(tǒng)硬件個(gè)方面,所以嵌入式工程師的就業(yè)方向要比一般的軟件
    發(fā)表于 04-21 15:23

    嵌入式軟件工程師嵌入式硬件工程師有什么不同,區(qū)別在哪里?

    不同。嵌入式硬件工程不但要求具備硬件工程師的基本技能,還必須完成部分軟件工程師的工作,例如: 底
    發(fā)表于 07-15 16:01

    嵌入式工程師是做什么的?

    嵌入式工程師了。嵌入式工程師主要做嵌入式系統(tǒng)設(shè)計(jì)和開發(fā),包括
    發(fā)表于 08-08 14:59

    成為高級(jí)嵌入式系統(tǒng)硬件工程師要具備什么技能?

    什么是嵌入式系統(tǒng)?嵌入式系統(tǒng)有哪些分類?成為高級(jí)嵌入式系統(tǒng)
    發(fā)表于 04-13 06:53

    關(guān)于嵌入式系統(tǒng)開發(fā)工程師相關(guān)問題解答

    技術(shù)支持。 三:職業(yè)要求 對(duì)于一個(gè)合格的嵌入式系統(tǒng)開發(fā)工程師來說至少2年以上嵌入式軟件開發(fā)經(jīng)驗(yàn)和嵌入式
    發(fā)表于 09-09 10:43

    如何才算嵌入式工程師入門了?

    【如何才算嵌入式工程師入門了?】 嵌入式應(yīng)用工程師是一個(gè)硬件兼顧的職業(yè)。當(dāng)然,到了具體的工作崗
    發(fā)表于 11-09 08:41

    什么是嵌入式硬件工程師?什么是嵌入式軟件工程師

    什么是嵌入式硬件工程師?什么是嵌入式軟件工程師?嵌入式軟件
    發(fā)表于 12-24 06:41

    嵌入式軟件工程師是什么?

    1.嵌入式軟件工程師是什么?嵌入式系統(tǒng)一般由嵌入式微處理器、外圍硬件設(shè)備、
    發(fā)表于 12-24 06:35

    嵌入式工程師有發(fā)展前途嗎?

    or 項(xiàng)目總監(jiān) 8年以上工作經(jīng)驗(yàn) 30-50k創(chuàng)業(yè)CEO 10年以上工作經(jīng)驗(yàn) 50k++工作崗位: C++開發(fā)工程師、QT開發(fā)軟件工程是、嵌入式軟件開發(fā)
    發(fā)表于 12-29 09:45

    嵌入式軟件工程師嵌入式硬件工程師有什么區(qū)別

    隨著嵌入式技術(shù)的普及,硬件工程師的性質(zhì)也有所改變。嵌入式硬件工程師與我們平常所說的
    的頭像 發(fā)表于 04-08 08:58 ?7.1w次閱讀

    嵌入式工程師入門技巧

    嵌入式應(yīng)用工程師是一個(gè)硬件兼顧的職業(yè)。當(dāng)然,到了具體的工作崗位可能會(huì)有嵌入式硬件
    的頭像 發(fā)表于 09-12 10:29 ?3136次閱讀

    硬件工程師請(qǐng)牢記這十大技巧

    這些建議是在我從硬件工程師過渡至軟件工程師期間,曾經(jīng)希望得到的建議。 嵌入式系統(tǒng)設(shè)計(jì)不僅要求了解硬件
    的頭像 發(fā)表于 05-02 11:49 ?6158次閱讀