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

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

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

從硬件轉(zhuǎn)向軟件設(shè)計,硬件工程師請牢記這十大技巧

lPCU_elecfans ? 來源:未知 ? 作者:肖冰 ? 2019-07-05 14:14 ? 次閱讀

嵌入式系統(tǒng)設(shè)計不僅要求了解硬件,還要求了解軟件的作用方式,以及如何與之交互。設(shè)計硬件需要的某種范式可能與設(shè)計軟件完全相反。當(dāng)從硬件設(shè)計轉(zhuǎn)向包含軟件的設(shè)計時 ,硬件工程師應(yīng)牢記以下十個技巧。

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

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

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

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

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

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

技巧4:利用模塊性的好處

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

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

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

技巧6:使用處理器示例代碼做外設(shè)的實驗

設(shè)計硬件時,做原型測試電路總是有益的,這樣可確保工程師對電路有正確的理解,然后再做電路板 布局。此點對設(shè)計軟件也同樣適用。硅片制造 商通常都有示例代碼,可用來測試微處理器的各個部分,這樣工程師們就可判定該部分的工作情況。此方法使人們洞察到軟件體系架構(gòu)的應(yīng)該組織方式,以及可能造成的任何潛在問題。在設(shè)計初期階段認(rèn)清潛在的障礙,比在產(chǎn)品交付前最后幾小時才發(fā)現(xiàn)它們要好。這是預(yù)先測試代碼片段的一個很好的方法,但需提醒的是,制造商代碼往往不是模塊化的,未經(jīng)大的修改不方便用于實際應(yīng)用。這一局限已隨著時間的發(fā)展而改變,也許某一天芯片供應(yīng)商會給出可用于生產(chǎn)的代碼。

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

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

無論在處理何種復(fù)雜工作時,最簡單的方法就是把它分解為更易處理的任務(wù)。

技巧8:使用源代碼存儲庫并頻繁提交

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

技巧9:代碼做詳細(xì)說明

在軟件開發(fā)的激烈戰(zhàn)斗中,開發(fā)人員很容易把注意力集中在編寫和代碼上,因此會忽略詳細(xì)解釋的需求。在壓力之下,說明工作往往是項目的收尾工作,因為開發(fā)人員認(rèn)為它是最后的一項工作。然而,當(dāng)代碼仍在你腦中新鮮熱火時就做出詳細(xì)解釋是至關(guān)重要的,這樣做可使開發(fā)人員或你自己讀懂注釋,理解代碼的工作方式。

如果開發(fā)人員做的一系列改變破壞了系統(tǒng),只需點擊一下即可恢復(fù)好的代碼版本!

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

無論做何種類型的工程工作,都建議您先設(shè)定并遵守一項流程。這樣的結(jié)果應(yīng)有一致的質(zhì)量和成本,并能按時交付。軟件開發(fā)人員已成功使用Agile開發(fā)流程來開發(fā)高質(zhì)量軟件。這一流程可按需求的優(yōu)先等級做開發(fā)。優(yōu)先級別最高的工作在限定的時間段內(nèi)首先開展,這被稱為迭代。這種方法的好處是它可使軟件開發(fā)流程保持順暢,還可以根據(jù)結(jié)果和客戶所需,在每次迭代中適應(yīng)并修改需求和任務(wù)。

技巧10A:站在開發(fā)技術(shù)之巔

要學(xué)習(xí)嵌入式軟件開發(fā)所使用的最新工具和技術(shù),最好的一個場合是嵌入式系統(tǒng)研討會(Embedded Systems Conferences)。該會議每年召開兩次,地點分別位于加利福尼亞州圣荷西(San Jose)和波士頓(east.ubmdesign.com)。會議吸引了來自全世界的工程師,他們可以開展互動、參加研討會,并進行實際操作,以促進對軟件開發(fā)的理解。此外,EDN.com社區(qū)還提供了與軟件和硬件相關(guān)的一系列網(wǎng)站,工程師們可通過不斷的參與和學(xué)習(xí),為了將最尖端技術(shù)應(yīng)用于他們未來的發(fā)展項目而做好準(zhǔn)備。

為了幫助大家更好的學(xué)習(xí)嵌入式系統(tǒng)、軟硬件設(shè)計知識、項目管理,我們?yōu)榇藢iT組建了一個工程師互動答疑群。如果你有關(guān)于硬件工程師職業(yè)規(guī)劃、電路設(shè)計或者項目管理方面的問題,都可以加入我們的交流群,就工程師相關(guān)問題咨詢老師,老師會幫助解答您的疑惑。

答疑老師

白紀(jì)龍:上市公司的研發(fā)團隊負(fù)責(zé)人,10余年工作經(jīng)驗,專攻物聯(lián)網(wǎng)AI等熱門領(lǐng)域資深硬件工程師,被多家知名企業(yè),高校受邀內(nèi)訓(xùn)。

上課機制:群滿300人后,每天10點助理老師會在群里收集問題,并精選10個問題。每天晚上20:00,白老師會在群里為大家集中答疑。

面向人群:

硬件工程師、電子工程師、嵌入式工程師、應(yīng)屆畢業(yè)生

點撥方向:

職場規(guī)劃、項目管理、硬件設(shè)計、高速PCB設(shè)計

往期問答

1.這兩種RC濾波有什么好處跟區(qū)別呢?

答:RC串聯(lián)一般是用用來消除阻尼振蕩,或者讓電路中可能存在電感等在開關(guān)過程產(chǎn)生電壓激變超過峰值電壓,RC串聯(lián)電路就可以通過充放電選擇合適的電阻就可以把這一能量消除或者減少,這種電路也叫snubber circuit,在反激式開關(guān)電源電路設(shè)計中經(jīng)常用到

2.兩級差分放大怎么理解?

答:?典型的儀表運放是先差分放大然后減法電路,理解最關(guān)鍵點在于Rg。其實儀表運放和一般運放的功能是一樣的,主要在于針對性的一些參數(shù)優(yōu)化上,因為對于儀表設(shè)計里的小信號為主的信號檢測而言,對于更高的輸入阻抗和更高的PSRR,低失調(diào)電壓電流等參數(shù)要求比較高,因此才會有儀表運放一說。但是儀表運放比較貴,所以很多公司就自己搭這個電路

3.本身是學(xué)材料的,想跳槽去搞硬件研發(fā),但是總感覺電路博大精深,不可能什么都懂,怎么辦?

答:可以先拿公司的產(chǎn)品自己一個元器件的繪制,然后仿照PCB一步一步的layout出來,慢慢地學(xué)會基本套路,如果有時間的話可以學(xué)習(xí)我這次眾籌課程的第一大部分,我會比較詳細(xì)的系統(tǒng)化的教大家如何全體系的學(xué)習(xí)

4. 現(xiàn)在從事器件可靠性,想轉(zhuǎn)硬件工程師或者電子工程師,對器件一塊比較熟悉,但是其他方面比較薄弱,我應(yīng)該從哪方面入手?畫板開始?還是接觸一個項目來由淺入深?

答:最好是從接觸一個項目開始。如果只是單獨的畫板的話,那只是公司的其中一個環(huán)節(jié)。如果說有一個項目,整個項目做下來的話,對該項目細(xì)節(jié)就會了解的比較全面,之后再做新的項目的時候,就會比較順暢。所以如果說是從項目開始接手進來………..

為保證互動體驗,答疑群將嚴(yán)格限制報名人數(shù),滿員即止。

有任何疑問,可掃碼添加助教老師入群(18138814636/18145814587)

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

    關(guān)注

    252

    文章

    766

    瀏覽量

    95569

原文標(biāo)題:從硬件轉(zhuǎn)向軟件設(shè)計,硬件工程師請牢記這十大技巧

文章出處:【微信號:elecfans,微信公眾號:電子發(fā)燒友網(wǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    硬件工程師找工作必備書籍推薦

    硬件工程師找工作必備書籍推薦
    的頭像 發(fā)表于 09-24 16:07 ?441次閱讀
    <b class='flag-5'>硬件</b><b class='flag-5'>工程師</b>找工作必備書籍推薦

    硬件工程師如何做元器件變更的決策

    硬件工程師如何做元器件變更的決策某產(chǎn)品在從研發(fā)轉(zhuǎn)規(guī)模生產(chǎn)階段,采購部門給硬件工程師推薦了新的MOSFET(稱為A),該物料比該產(chǎn)品研發(fā)階段使用的MOSFET(稱為B)價格更低,且供貨渠
    的頭像 發(fā)表于 07-06 08:17 ?373次閱讀
    <b class='flag-5'>硬件</b><b class='flag-5'>工程師</b>如何做元器件變更的決策

    找STM32硬件開發(fā)兼職工程師

    上海做傳感器的公司,找STM32硬件開發(fā)兼職工程師,會硬件開發(fā),嵌入式軟件開發(fā),可項目外包。有意聯(lián)系:15900460170
    發(fā)表于 06-22 19:12

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

    嵌入式軟件工程師硬件工程師的區(qū)別? 嵌入式軟件工程師 嵌入式軟件工程師軟件開發(fā)領(lǐng)域中的一種專
    發(fā)表于 05-16 11:00

    如何入門硬件工程師

    想跨行業(yè)做硬件設(shè)計工程師,應(yīng)該如何學(xué)習(xí)規(guī)劃呢
    發(fā)表于 03-17 21:49

    硬件工程師面試時候最容易遇到的個問題,你知道幾個呢?#電路原理 #工作原理大揭秘 #電路知識

    電路硬件工程師
    MDD辰達(dá)行半導(dǎo)體
    發(fā)布于 :2024年03月01日 16:49:56

    如何搞崩一個硬件工程師心態(tài)?試試對ta說這幾句

    硬件工程師
    揚興科技
    發(fā)布于 :2024年02月20日 18:05:49

    有沒有誰做過DSP、微型逆變器/微逆變/大型工業(yè)逆變器、嵌入式軟件的軟硬件高級工程師

    急需 DSP、微型逆變器/微逆變/大型工業(yè)逆變器、嵌入式軟件等豐富經(jīng)驗的軟件高級工程師、硬件高級工程師,深圳,面議面議,自薦/推薦
    發(fā)表于 12-14 17:32

    硬件工程師必備的音頻功放電路大全

    硬件工程師必備的音頻功放電路大全
    的頭像 發(fā)表于 12-07 17:25 ?1105次閱讀
    <b class='flag-5'>硬件</b><b class='flag-5'>工程師</b>必備的音頻功放電路大全

    嵌入式硬件軟件哪個好?

    嵌入式硬件軟件哪個好? 嵌入式軟硬件工程師哪個更有前途呢?一起來看看。 嵌入式是分為軟硬件工程師
    發(fā)表于 12-05 15:17

    硬件工程師經(jīng)典面試題詳解

    硬件工程師經(jīng)典面試題詳解
    的頭像 發(fā)表于 11-20 15:08 ?1297次閱讀
    <b class='flag-5'>硬件</b><b class='flag-5'>工程師</b>經(jīng)典面試題詳解