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

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

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

資深工程師教您巧做單片機(jī)項(xiàng)目的思路方法

UtFs_Zlgmcu7890 ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2017-11-30 08:02 ? 次閱讀
對(duì)于一個(gè)沒有太多程序設(shè)計(jì)經(jīng)驗(yàn)的萌新工程師來說,如何有規(guī)劃有條理的進(jìn)行程序設(shè)計(jì),是一個(gè)很值得學(xué)習(xí)的課題。在本文中,作者結(jié)合自身的經(jīng)驗(yàn),淺要的談一談項(xiàng)目中的程序設(shè)計(jì)思路與步驟。


我們平時(shí)在學(xué)習(xí)開發(fā)板、示例程序或者demo的時(shí)候,會(huì)發(fā)現(xiàn)這種程序設(shè)計(jì)都是單一的外設(shè)或者功能,功能實(shí)現(xiàn)就算演示成功。但是在實(shí)際的項(xiàng)目設(shè)計(jì)過程中,往往需要設(shè)計(jì)的程序是非常龐大且復(fù)雜的,項(xiàng)目的功能和項(xiàng)目需求可能會(huì)超級(jí)多。此時(shí)在程序設(shè)計(jì)中,既要使MCU同時(shí)兼顧各個(gè)外設(shè)而不發(fā)生沖突,又要合理的設(shè)計(jì)程序構(gòu)架,使所有的需求都能邏輯清晰的實(shí)現(xiàn)相關(guān)功能。

所以程序設(shè)計(jì)一定要有思路。當(dāng)我們拿到一份項(xiàng)目需求的時(shí)候,不能一上來就敲代碼,最后隨跳躍的思維寫出來的程序邏輯把自己都繞暈了還沒能實(shí)現(xiàn)所有功能。就像蓋高樓前一定要有圖紙一樣,在進(jìn)行程序設(shè)計(jì)前也要有程序構(gòu)架。

程序框架與底層無關(guān),它重在整體需求的實(shí)現(xiàn)與邏輯關(guān)系。例如我們把一個(gè)具體的項(xiàng)目需求細(xì)化為10個(gè)具體的任務(wù),每個(gè)任務(wù)都完成一些特定的功能。先忽略每個(gè)任務(wù)里的內(nèi)容,這10個(gè)任務(wù)和它們之間的切換邏輯就組成了此項(xiàng)目的程序構(gòu)架。

有了程序設(shè)計(jì)構(gòu)架,接下來就是實(shí)現(xiàn)每一個(gè)任務(wù)具體的功能,不同的部分分模塊編寫,例如外設(shè)單獨(dú)寫一個(gè)文件,傳感器驅(qū)動(dòng)單獨(dú)列一個(gè)文件,所有文件之間相互獨(dú)立,這樣不僅思路清晰,且在排查問題的時(shí)候,能直接屏蔽某一個(gè)文件,更快速的定位問題所在。

有了思路之后,接下來我們談一談具體的設(shè)計(jì)步驟。假設(shè)此時(shí)我們拿到了一個(gè)具體的項(xiàng)目需求書。1項(xiàng)目規(guī)劃

首先把需求拆分,分為一個(gè)個(gè)任務(wù),每一個(gè)任務(wù)去實(shí)現(xiàn)相應(yīng)的部分功能,設(shè)計(jì)好任務(wù)之間的切換條件。此時(shí)暫且不考慮底層,只是列出所有任務(wù)和任務(wù)之間的邏輯切換關(guān)系,這樣就有了程序構(gòu)架,然后再規(guī)劃每個(gè)任務(wù)里面里面需要多少具體功能,列出來一個(gè)表,或者寫成空函數(shù)先放著。列完每個(gè)任務(wù)的具體功能之后,我們?cè)倩仡^看需求書,是否所有功能都實(shí)現(xiàn),且它們之間的切換關(guān)系邏輯都很清晰。

2功能模塊化

第一步完成之后,整體的系統(tǒng)構(gòu)架和邏輯關(guān)系就一清二楚了,接下來我們按照第一步中列的每個(gè)任務(wù)的功能表,去完成具體功能實(shí)現(xiàn)。此時(shí),還不急著敲代碼,繼續(xù)規(guī)劃。我們知道,對(duì)于MCU來講,通常所有的功能最終是要通過調(diào)用底層實(shí)現(xiàn)。所以接下來我們要規(guī)劃需要多少底層的資源,根據(jù)第一條中任務(wù)具體的功能列表,我們列一個(gè)底層驅(qū)動(dòng)表。例如功能需要使用UART,SPI等這些外設(shè)資源,所有外設(shè)資源列成一個(gè)外設(shè)表,表中是所有需要使用的外設(shè)資源。如果還需要其他驅(qū)動(dòng),例如傳感器、LCD、FLASH等,所有器件列一個(gè)器件驅(qū)動(dòng)表。

3編寫外設(shè)驅(qū)動(dòng)

有了第一步和第二步從上向下的規(guī)劃,此時(shí)我們應(yīng)該已經(jīng)很清楚這個(gè)項(xiàng)目需求書如何變成代碼實(shí)現(xiàn)。此時(shí),開始編寫程序,從下向上,逐層編寫。

首先要根據(jù)外設(shè)表編寫每個(gè)外設(shè)對(duì)應(yīng)的驅(qū)動(dòng),每個(gè)外設(shè)驅(qū)動(dòng)單獨(dú)列一個(gè)文件,編寫好之后驗(yàn)證功能是否正常,這個(gè)步驟跟本文開頭提到的開發(fā)板示例程序類似,很基礎(chǔ)。如果同一個(gè)外設(shè),需要同時(shí)實(shí)現(xiàn)幾路輸出或輸入,例如需要三個(gè)不同的IIC輸出,那就同時(shí)啟動(dòng)三路IIC驗(yàn)證功能是否都正常,每一路之間會(huì)不會(huì)有干擾。

每編寫一個(gè)驅(qū)動(dòng),一定要對(duì)驅(qū)動(dòng)中的每一個(gè)函數(shù)進(jìn)行功能驗(yàn)證。只有底層沒問題,才能往上封裝。

4編寫器件驅(qū)動(dòng)

因?yàn)槠骷尿?qū)動(dòng)很多都是以外設(shè)驅(qū)動(dòng)為基礎(chǔ)的,所以寫完外設(shè)驅(qū)動(dòng)之后,利用外設(shè)驅(qū)動(dòng)的函數(shù),去實(shí)現(xiàn)器件的驅(qū)動(dòng),例如FLASH,可能是SPI通信的,那么我們首先要寫好SPI驅(qū)動(dòng)文件,然后調(diào)用SPI驅(qū)動(dòng)文件,編寫FLASH驅(qū)動(dòng)文件,完成具體的功能函數(shù),例如FLASH的擦除,讀寫等。

同樣,每一個(gè)編寫的器件驅(qū)動(dòng)都要對(duì)每一個(gè)函數(shù)進(jìn)行測(cè)試。

5其它驅(qū)動(dòng)的編寫

可能在項(xiàng)目中,還涉及到一些無關(guān)底層的東西,例如一些加密算法,復(fù)雜的數(shù)據(jù)處理算法,各類通信協(xié)議等??梢园衙恳活惙譃橐粋€(gè)模塊,編寫或者移植完之后一定要驗(yàn)證每一個(gè)函數(shù)的功能。

6實(shí)現(xiàn)任務(wù)里的功能函數(shù)

驅(qū)動(dòng)文件都準(zhǔn)備好了之后,就利用驅(qū)動(dòng)文件,加上必要的數(shù)據(jù)處理,去完成任務(wù)里的每一個(gè)具體的功能函數(shù)。

同樣,每一個(gè)編寫的功能函數(shù)都要進(jìn)行測(cè)試。保證功能正常實(shí)現(xiàn)。

7任務(wù)測(cè)試

完成步驟6之后,要對(duì)每一個(gè)任務(wù)進(jìn)行測(cè)試,看是否能實(shí)現(xiàn)規(guī)劃中要求的功能。

8系統(tǒng)測(cè)試

完成步驟7之后,項(xiàng)目基本完工,因?yàn)槊恳粚佣际墙?jīng)過測(cè)試的,所以整個(gè)系統(tǒng)也不會(huì)有太大問題,但是也可能存在一些例如邏輯或者資源沖突的錯(cuò)誤。此時(shí)按照需求書要求的功能對(duì)整個(gè)系統(tǒng)進(jìn)行反復(fù)測(cè)試,查找可能存在的問題,進(jìn)一步完善程序。

9注意事項(xiàng)

在整個(gè)設(shè)計(jì)過程中,還有一些其他的注意事項(xiàng),例如:

● 如果開了很多中斷,一定要對(duì)每個(gè)中斷設(shè)置優(yōu)先級(jí)。明確哪個(gè)優(yōu)先級(jí)應(yīng)該優(yōu)先處理。

● 相同優(yōu)先級(jí)下的兩個(gè)中斷,禁止在第一個(gè)中斷中觸發(fā)第二中斷,程序會(huì)卡死。

● 少用全局變量,系統(tǒng)運(yùn)行時(shí)必要的變量和狀態(tài)可以都放在結(jié)構(gòu)體中。然后只定義一個(gè)結(jié)構(gòu)體變量。

● 當(dāng)結(jié)構(gòu)體的成員為不同數(shù)據(jù)類型時(shí),成員排序就顯得很重要,優(yōu)化排序會(huì)節(jié)約很多內(nèi)存。

● 結(jié)構(gòu)體做形參的時(shí)候,為減少??臻g的開支,最好設(shè)置結(jié)構(gòu)體指針類型的形參。

● 不可以返回指向??臻g的指針。

● 如果通信接收或者發(fā)送沒有硬件FIFO,可以編寫軟件FIFO,避免丟包。

● 所有變量要初始化具體數(shù)值,尤其是局部變量。

● 定義指針類型變量一定要初始化。

● 只在本文件里使用的函數(shù)或者全局變量,一定要加static。

● 頭文件中只能聲明,不可以定義。

● 一定要添加合適的注釋,大部分時(shí)候代碼不知自己看。

● 使用數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)或者處理數(shù)據(jù),例如結(jié)構(gòu)體、枚舉、鏈表、隊(duì)列等。

看完這些步驟,是不是覺得復(fù)雜項(xiàng)目的程序設(shè)計(jì)原來也挺簡單的,那就愉快的開始程序設(shè)計(jì)之路吧。

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

原文標(biāo)題:淺談項(xiàng)目中的程序設(shè)計(jì)思路與步驟

文章出處:【微信號(hào):Zlgmcu7890,微信公眾號(hào):周立功單片機(jī)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    TI工程師掌控自己的電源設(shè)計(jì)

    TI工程師掌控自己的電源設(shè)計(jì)
    發(fā)表于 08-04 09:41

    跪求單片機(jī)高手,資深電子工程師指點(diǎn)

    如果您是單片機(jī)高手,資深電子工程師,請(qǐng)留步觀看!本人欲學(xué)習(xí)單片機(jī),各位高人如有較為系統(tǒng)的資料、書籍、光盤,請(qǐng)不不吝賜教!十分感謝!郵箱:dingyanming0903@163.com
    發(fā)表于 01-08 17:20

    工程師掌控自己的電源設(shè)計(jì)

    工程師掌控自己的電源設(shè)計(jì)
    發(fā)表于 04-16 20:48

    工程師掌控自己的電源設(shè)計(jì)

    工程師掌控自己的電源設(shè)計(jì)
    發(fā)表于 04-16 20:53

    此書幫你深入學(xué)習(xí)單片機(jī)成為資深高級(jí)工程師

    本帖最后由 冰葑世紀(jì) 于 2013-7-29 00:42 編輯 如果你覺得你的單片機(jī)有了一定水平,但還是成不了資深或者高級(jí)工程師,那么,下面的資料幫你實(shí)現(xiàn)這個(gè)愿望,下載地址:[hide][/hide]
    發(fā)表于 07-23 15:05

    【社區(qū)之星】如何成為一位“合格”的資深電子工程師

    。技術(shù)的合作與共享,是一個(gè)有利于大家、有利于千秋的事情,所以我希望工程師能在社會(huì)中擺正自己的位置,與社會(huì)融為一體,以促進(jìn)社會(huì)技術(shù)的跨時(shí)代大發(fā)展。 9、電子發(fā)燒友:出的《單片機(jī)編程魔法師之高級(jí)裸編程
    發(fā)表于 11-24 15:55

    資深工程師的進(jìn)階之道

    ARM嵌入式和單片機(jī)學(xué)習(xí)有著密不可分的關(guān)系,在學(xué)習(xí)單片機(jī)的過程中積累必要的學(xué)習(xí)經(jīng)驗(yàn)和知識(shí)是非常有必要的,如何在這一過程中逐漸成為高級(jí)嵌入式工程師呢?本文將為大家介紹如何在學(xué)習(xí)過程中,積累成為高級(jí)
    發(fā)表于 09-27 15:15

    資深工程師與你分享單片機(jī)學(xué)習(xí)經(jīng)驗(yàn)

    錢嗎?企業(yè)還會(huì)為找不到高技術(shù)人才而發(fā)愁嗎?再說了,企業(yè)敢用只學(xué)了10天的單片機(jī)工程師嗎?希望讀者能像筆者一樣,掌握正確的方法之后,堅(jiān)持去玩。2.熟練軟件開發(fā)工具開發(fā)工具軟件一定要熟練。說到開發(fā)工具,因?yàn)?/div>
    發(fā)表于 10-12 09:28

    國內(nèi)控制器龍頭行業(yè)招聘資深算法工程師

    國內(nèi)智能控制器龍頭企業(yè)研究院招聘資深算法工程師,工作地點(diǎn):南山科技園,有興趣請(qǐng)聯(lián)系:kezhq@126.comqq:12530691 謝謝資深算法工程師5年以上
    發(fā)表于 01-26 17:45

    前華為資深工程師帶你玩轉(zhuǎn)嵌入式軟件調(diào)試方法

    內(nèi)容面向哪些人群:嵌入式軟件開發(fā)工程師、單片機(jī)軟件開發(fā)工程師、軟件開發(fā)工程師等 參與直播將獲得如下知識(shí)點(diǎn):1、了解嵌入式軟件開發(fā)主流的調(diào)試手段2、CLI設(shè)計(jì)原理和源碼實(shí)現(xiàn)3、如何制作一
    發(fā)表于 10-18 15:48

    前華為資深工程師帶你玩轉(zhuǎn)嵌入式軟件調(diào)試方法(附命令行代碼)

    。本次直播主要介紹軟件調(diào)試幾種主流方法,重點(diǎn)詳細(xì)講解CLI的設(shè)計(jì)原理和源代碼實(shí)現(xiàn)并如何制作一個(gè)自己的CLI。直播內(nèi)容面向哪些人群:嵌入式軟件開發(fā)工程師、
    發(fā)表于 10-19 12:00

    【高手問答】資深工程師版主殷培與聊聊不一樣的LabVIEW

    的事兒【高手問答】第14期——如何升華51單片機(jī)基礎(chǔ),成為一個(gè)出色的開發(fā)工程師。【高手問答】第13期——向資深PCB設(shè)計(jì)取經(jīng):如何設(shè)計(jì)高速PCB【高手問答】第12期——韋東山老師VS
    發(fā)表于 08-28 13:58

    單片機(jī)初學(xué)者邁向單片機(jī)工程師

    單片機(jī)初學(xué)者邁向單片機(jī)工程師單片機(jī)初學(xué)者邁向單片機(jī)工程師
    發(fā)表于 01-15 16:33 ?45次下載

    工程師單片機(jī)學(xué)習(xí)經(jīng)驗(yàn)技巧

    工程師單片機(jī)學(xué)習(xí)經(jīng)驗(yàn)技巧
    發(fā)表于 01-22 21:11 ?24次下載

    資深工程師單片機(jī)項(xiàng)目經(jīng)驗(yàn)分享

    資深工程師單片機(jī)項(xiàng)目經(jīng)驗(yàn)分享,條條真理!
    的頭像 發(fā)表于 05-30 17:13 ?3327次閱讀
    <b class='flag-5'>資深</b><b class='flag-5'>工程師</b><b class='flag-5'>單片機(jī)</b><b class='flag-5'>項(xiàng)目</b>經(jīng)驗(yàn)分享