99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

開發(fā)單片機(jī)程序時常犯的一個錯誤

GReq_mcu168 ? 來源:cg ? 2018-12-23 14:11 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

這里利用一個實(shí)際發(fā)生的例子,針對初級工程師經(jīng)常犯的一個小錯誤,或者經(jīng)常要走的一個彎路,做了針對性的糾正。希望可以幫到大家,文筆不好文章中有敘述不清的地方大家多多指教。

這篇文章我不是想說編程的規(guī)范性的東西,如果你想讓自己的程序文件最起碼直觀的看起來美觀、可讀性強(qiáng),推薦找華為的“C語言編程規(guī)范”。我只想說一說當(dāng)我們的單片機(jī)遇到多個模塊的數(shù)據(jù)需要處理,類似于“多任務(wù)”時我們應(yīng)該怎么辦?

背景是這樣的,去年9月份開始安排一個工程師開始做電動汽車交流充電樁機(jī)械設(shè)計(jì)部分由公司機(jī)械結(jié)構(gòu)部門負(fù)責(zé)。充電樁的電子部分總體上分為X個部分(用到的資源),電阻觸摸屏(RS232),M1卡讀寫(RS232),電能計(jì)量表(RS485),語音提示(SPI),電力開關(guān)(繼電器IO),通訊接口(RS485、CAN)。工程師做的過程非常勤奮,期間也是困難重重,改了很多個版本,總算今年6月把充電樁立起來了。咱們來驗(yàn)收一下吧,結(jié)果發(fā)現(xiàn)讀卡的時候不能處理觸摸屏,播放語音的時候不能處理讀卡,語音播放不能打斷或者跳躍,反正就是所有事件必須一個一個按部就班的來,一旦操作錯誤就需要多次執(zhí)行、等待、甚至重新來過。一個工作3年多的工程師怎么會把產(chǎn)品做成這樣呢?看看程序吧!一看不要緊,嚇一跳!整個的程序是沒有邏輯的,一條線就往下寫……

While(1){//上電進(jìn)入主程序 或 觸發(fā)觸摸屏//播放提示語音Delay();//等待播放完畢//讀取M1卡信息Delay();//等待讀卡數(shù)據(jù)返回//播放提示語音Delay();//等待播放完畢//M1卡數(shù)據(jù)交互,判定下一步操作及提示Delay();//等待數(shù)據(jù)處理完畢…………}

這里說這個工程師基本上對于自己設(shè)計(jì)的產(chǎn)品沒有任何的整體概念,或者說對自己開發(fā)的程序用到設(shè)計(jì)上會有怎樣的實(shí)際效果根本就不清楚。他犯了幾個我們在程序開發(fā)過程中最忌諱的幾個問題:

1、 delay(死等)這類函數(shù)只在應(yīng)該實(shí)驗(yàn)室驗(yàn)證某個功能過程中用到,在實(shí)際的產(chǎn)品開發(fā)時無論是主循環(huán)while中,還是其調(diào)用的函數(shù)中,亦或是中斷服務(wù)程序中絕對不可以用到。

2、 產(chǎn)品設(shè)計(jì)的各個子模塊之間的邏輯關(guān)系太強(qiáng),例如:必須等待播音完畢才能讀卡進(jìn)入下一步操作等。我們講,產(chǎn)品設(shè)計(jì)中只有各個事件處理模塊間的邏輯關(guān)系弱化,才能更加靈活的進(jìn)行處理。例如:兩個事件A和B,如果程序開發(fā)時將A做成B事件的必要條件,B事件的觸發(fā)就必須等待A事件的發(fā)生。反之如果A事件作為B事件處理的一個特殊情況,那么程序開發(fā)起來就變得靈活很多。

3、 沒有考慮到單片機(jī)本身是一個單核單任務(wù)的架構(gòu),每一個事件都會獨(dú)占CPU內(nèi)核,當(dāng)多個任務(wù)模塊同時存在時我們應(yīng)該對各個事件進(jìn)行區(qū)分,我們應(yīng)當(dāng)分情況、分事件實(shí)時性要求等區(qū)分對待。那么針對于這樣的問題,或者是遇到類似的項(xiàng)目我們應(yīng)該如何處理呢?我提幾條建議:

1、將硬件系統(tǒng)區(qū)分為獨(dú)立單元單獨(dú)做成底層驅(qū)動函數(shù)和應(yīng)用函數(shù),并且函數(shù)正常應(yīng)該有參數(shù)和返回值,其中返回值是必要的。如何衡量這類函數(shù)呢?這類函數(shù)可移植性強(qiáng),只要一個.h文件和一個.c文件就可以隨意放到任何工程中。例如:語音播放、M1讀卡、485處理等等。

2、將1中的所有函數(shù)進(jìn)行時間評估,評估點(diǎn)有兩個。一個是函數(shù)的執(zhí)行時間t,第二個是函數(shù)的周期性發(fā)生的時間T,一個最基本的條件是t < T,理想情況應(yīng)該是t << T。

3、建立一個集中邏輯處理函數(shù),在這個函數(shù)中對1中的各個函數(shù)進(jìn)行調(diào)度。這個函數(shù)發(fā)揮的作用相當(dāng)于嵌入式系統(tǒng)中的系統(tǒng)調(diào)度。這種調(diào)度是整個硬件邏輯中所有事件處理的調(diào)度,它的目的是完成一個處理過程,但是絕不依賴于任意事件的必要處理過程。這樣就將問題2中提到的事件間的邏輯關(guān)系弱化了,處理起來變得十分靈活,使得各個關(guān)系不在相互必要。

4、為了保證前面內(nèi)容的正常實(shí)施還需要針對各類事件的周期,建立一個必要的時間管理函數(shù),時間函數(shù)的基礎(chǔ)一般情況下由一個內(nèi)部定時器的中斷來完成,中斷的周期一般我們考慮5-10ms。按照實(shí)際需求將N個定時器中斷定義為一個事件處理的周期TT,這個周期應(yīng)該保證處理完最惡劣情況可能發(fā)生的所有t,且保證TT < T。

5、 這其中也有例外,一些實(shí)時性要求高的事件應(yīng)當(dāng)用中斷完成。其中中斷處理函數(shù)的處理事件應(yīng)盡量短,時間要求參見2。

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

    關(guān)注

    6067

    文章

    44992

    瀏覽量

    650689
  • 程序
    +關(guān)注

    關(guān)注

    117

    文章

    3826

    瀏覽量

    83017

原文標(biāo)題:單片機(jī)程序開發(fā)時,初級工程師常犯的一個錯誤

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    關(guān)于C語言編程時常犯錯誤匯總

    17C語言新手編程時常犯錯誤及解決方式
    的頭像 發(fā)表于 06-26 09:19 ?6432次閱讀
    關(guān)于C語言編程<b class='flag-5'>時常犯</b>的<b class='flag-5'>錯誤</b>匯總

    18C語言新手編程時常犯錯誤及解決方式

    ,經(jīng)常會出些連自己都不知道錯在哪里的錯誤。看著有錯的程序,不知該如何改起,本人通過對C的學(xué)習(xí),積累了些C編程時常犯
    發(fā)表于 01-03 15:35 ?1264次閱讀

    單片機(jī)程序開發(fā)時,常犯錯誤

    果A事件作為B事件處理的特殊情況,那么程序開發(fā)起來就變得靈活很多。3、 沒有考慮到單片機(jī)本身是
    發(fā)表于 05-05 11:53

    請問怎樣使用eclipse去開發(fā)單片機(jī)程序

    怎樣使用eclipse去開發(fā)單片機(jī)程序?在使用Eclipse新建工程時,記錄碰到的問題都是怎么解決的?
    發(fā)表于 07-01 06:01

    開發(fā)單片機(jī)過程中有哪些步驟

    就兩步驟,程序代碼的編寫與程序的燒錄(將單片機(jī)程序寫入開發(fā)板的ROM中),分別在以下兩款軟件中
    發(fā)表于 07-13 09:18

    開發(fā)單片機(jī)程序時碰到編譯錯誤

    我們在開發(fā)單片機(jī)程序的時候,經(jīng)常會碰到編譯沒有錯誤,程序代碼反復(fù)的檢查,但就是找不到問題所在,不知道問題到底出現(xiàn)在哪里了?這個時候的心情就會特別煩躁,
    發(fā)表于 11-18 07:30

    擺脫仿真器的AVR單片機(jī)程序開發(fā)設(shè)計(jì)

    開發(fā)單片機(jī)程序時,有許多人依賴于仿真機(jī),旦離開了仿真機(jī)開發(fā)
    發(fā)表于 02-11 08:46 ?1179次閱讀

    C語言編程時常犯的18種錯誤

    C語言的最大特點(diǎn)是:功能強(qiáng)、使用方便靈活。C編譯的程序對語法檢查并不象其它高級語言那么嚴(yán)格,這就給編程人員留下“靈活的余地”,但還是由于這個靈活給程序的調(diào)試帶來了許多不便,尤其對初學(xué)C語言的人來說,經(jīng)常會出些連自己都不知道錯在
    的頭像 發(fā)表于 02-27 14:51 ?6554次閱讀

    17C語言新手編程時常犯錯誤及解決方式

    。看著有錯的程序,不知該如何改起,通過對C的學(xué)習(xí),積累了些C編程時常犯錯誤,以供參考。 1、書寫標(biāo)識符時,忽略了大小寫字母的區(qū)別。 main() { int a=5; printf
    發(fā)表于 09-06 12:57 ?582次閱讀

    快速的開發(fā)單片機(jī)的技巧分享

    作為單片機(jī)開發(fā)的老司機(jī),在這里告訴大家如何快速的開發(fā)單片機(jī),完成自己的項(xiàng)目。
    的頭像 發(fā)表于 02-07 07:30 ?3084次閱讀

    開發(fā)單片機(jī)的集成開發(fā)環(huán)境工具(IDE)有哪些?

    IDE:Integrated Development Environment,集成開發(fā)環(huán)境。 IDE指用于軟件開發(fā)的工具,通常包含編輯器、編譯器、調(diào)試器、圖形用戶界面等集成多種工具的應(yīng)用程序。
    的頭像 發(fā)表于 06-29 11:22 ?1.8w次閱讀

    開發(fā)單片機(jī)常見的IDE有哪些?

    開發(fā)單片機(jī)常見的IDE有哪些?(點(diǎn)擊鏈接閱讀原文)
    發(fā)表于 11-13 12:36 ?12次下載
    <b class='flag-5'>開發(fā)單片機(jī)</b>常見的IDE有哪些?

    如何使用eclipse開發(fā)單片機(jī)程序

    如何使用eclipse開發(fā)單片機(jī)程序
    發(fā)表于 11-13 12:51 ?6次下載
    如何使用eclipse<b class='flag-5'>開發(fā)單片機(jī)</b><b class='flag-5'>程序</b>

    在Visual Studio Code上開發(fā)單片機(jī)程序(基于IAR msp430)

    在Visual Studio Code上開發(fā)單片機(jī)程序(基于IAR msp430)
    發(fā)表于 11-15 15:51 ?57次下載
    在Visual Studio Code上<b class='flag-5'>開發(fā)單片機(jī)</b><b class='flag-5'>程序</b>(基于IAR msp430)

    選擇示波器探頭時常犯錯誤(下)

    前面我們講了關(guān)于選擇示波器探頭的常犯3點(diǎn)錯誤,那么除了前面講的那些問題點(diǎn)外,我們還需要注意選擇示波器探頭時常犯錯誤呢?下面西安普科科技小編和大家講講:
    的頭像 發(fā)表于 11-11 14:47 ?2305次閱讀
    選擇示波器探頭<b class='flag-5'>時常犯</b>的<b class='flag-5'>錯誤</b>(下)