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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

單片機的程序開發(fā)經(jīng)常會出現(xiàn)那些錯誤

Wildesbeast ? 來源:網(wǎng)絡整理 ? 作者:佚名 ? 2021-01-09 10:41 ? 次閱讀

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

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

背景是這樣的,去年9月份開始安排一個工程師開始做電動汽車交流充電樁,機械設計部分由公司機械結構部門負責。充電樁的電子部分總體上分為X個部分(用到的資源),電阻觸摸屏(RS232),M1卡讀寫(RS232),電能計量表(RS485),語音提示(SPI),電力開關(繼電器IO),通訊接口(RS485、CAN)。

工程師做的過程非常勤奮,期間也是困難重重,改了很多個版本,總算今年6月把充電樁立起來了。

咱們來驗收一下吧,結果發(fā)現(xiàn)讀卡的時候不能處理觸摸屏,播放語音的時候不能處理讀卡,語音播放不能打斷或者跳躍,反正就是所有事件必須一個一個按部就班的來,一旦操作錯誤就需要多次執(zhí)行、等待、甚至重新來過。

一個工作3年多的工程師怎么會把產品做成這樣呢?看看程序吧!

一看不要緊,嚇一跳!整個的程序是沒有邏輯的,一條線就往下寫……

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

這里說這個工程師基本上對于自己設計的產品沒有任何的整體概念,或者說對自己開發(fā)的程序用到設計上會有怎樣的實際效果根本就不清楚。

他犯了幾個我們在程序開發(fā)過程中最忌諱的幾個問題:

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

2、 產品設計的各個子模塊之間的邏輯關系太強,例如:必須等待播音完畢才能讀卡進入下一步操作等。

我們講,產品設計中只有各個事件處理模塊間的邏輯關系弱化,才能更加靈活的進行處理。例如:兩個事件A和B,如果程序開發(fā)時將A做成B事件的必要條件,B事件的觸發(fā)就必須等待A事件的發(fā)生。反之如果A事件作為B事件處理的一個特殊情況,那么程序開發(fā)起來就變得靈活很多。

3、 沒有考慮到單片機本身是一個單核單任務的架構,每一個事件都會獨占CPU內核,當多個任務模塊同時存在時我們應該對各個事件進行區(qū)分,我們應當分情況、分事件實時性要求等區(qū)分對待。

那么針對于這樣的問題,或者是遇到類似的項目我們應該如何處理呢?

我提幾條建議:

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

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

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

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

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

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

    關注

    6037

    文章

    44558

    瀏覽量

    635353
  • RS485
    +關注

    關注

    39

    文章

    1159

    瀏覽量

    82332
  • C語言
    +關注

    關注

    180

    文章

    7604

    瀏覽量

    136840
收藏 人收藏

    評論

    相關推薦

    單片機程序總跑飛?小技巧幫你忙

    經(jīng)常接觸單片機的朋友,肯定遇到過單片機程序跑飛的問題。由于程序較為復雜,所以一旦出現(xiàn)跑飛的現(xiàn)象就
    發(fā)表于 04-02 09:58 ?8616次閱讀

    單片機BootLoader的通用實現(xiàn)方式

    單片機BootLoader的通用實現(xiàn)方式(備份升級,永不掛機)背景介紹實現(xiàn)方式背景介紹當我們在進行Linux下進行C語言程序開發(fā)時,由于C語言指針和內存的靈活性,經(jīng)常會出現(xiàn)
    發(fā)表于 07-21 06:55

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

    我們在開發(fā)單片機程序的時候,經(jīng)常會碰到編譯沒有錯誤,程序代碼反復的檢查,但就是找不到問題所在,不知道問題到底
    發(fā)表于 11-18 07:30

    程序開發(fā)經(jīng)常容易出現(xiàn)的問題匯總

    在剛開始接觸單片機學習的時候,尤其是C語言基礎比較薄弱的老鐵們,經(jīng)常會碰到很多比較低級的錯誤,程序編譯錯誤一大堆,但不知道如何解決!一、
    發(fā)表于 11-22 06:19

    使用GD芯片的AD采樣經(jīng)常會出現(xiàn)AD值為0是為什么?

    使用GD芯片的AD采樣經(jīng)常會出現(xiàn)AD值為0是為什么?
    發(fā)表于 02-16 07:50

    單片機的外部中斷使用經(jīng)常會出現(xiàn)那些問題應該如何解決

    通過分析51單片機外中斷I/O入口的內部結構,解釋了外中斷不能被正常響應的原因,并提出了解決該問題的方法。
    發(fā)表于 09-09 17:26 ?1次下載
    <b class='flag-5'>單片機</b>的外部中斷使用<b class='flag-5'>經(jīng)常會出現(xiàn)</b><b class='flag-5'>那些</b>問題應該如何解決

    51單片機經(jīng)常會出現(xiàn)的4點錯誤解決方法詳細說明

    本文檔的主要內容詳細介紹的是51單片機經(jīng)常會出現(xiàn)的4點錯誤解決方法詳細說明。
    發(fā)表于 09-06 17:26 ?0次下載
    51<b class='flag-5'>單片機</b><b class='flag-5'>經(jīng)常會出現(xiàn)</b>的4點<b class='flag-5'>錯誤</b>解決方法詳細說明

    JLINK_V8固件燒寫經(jīng)常會碰到那些常見的錯誤

    本文檔的主要內容詳細介紹的是JLINK_V8固件燒寫經(jīng)常會碰到那些常見的錯誤。
    發(fā)表于 08-16 17:32 ?4次下載
    JLINK_V8固件燒寫<b class='flag-5'>經(jīng)常會</b>碰到<b class='flag-5'>那些</b>常見的<b class='flag-5'>錯誤</b>

    內存經(jīng)常會出現(xiàn)那些故障?應該如何解決

    內存對于電腦的重要性不言而喻,缺少內存,電腦將無法正常運轉。如果內存發(fā)生故障,筆記本將同樣產生一些令人疑惑的錯誤。本文中,小編將對內存可能出現(xiàn)的故障以及相應的解決措施予以介紹。如果你對內存具有興趣,抑或您的電腦內存出現(xiàn)故障,不妨
    發(fā)表于 10-17 11:56 ?3780次閱讀

    2246EN開卡工具和經(jīng)常會出現(xiàn)的問題分析

    本文檔的主要內容詳細介紹的是2246EN開卡工具應用程序經(jīng)常會出現(xiàn)的問題分析。
    發(fā)表于 11-23 08:00 ?15次下載
    2246EN開卡工具和<b class='flag-5'>經(jīng)常會出現(xiàn)</b>的問題分析

    Python新手經(jīng)常會那些錯誤

    當初學Python 時,想要弄懂Python 的錯誤信息的含義可能有點復雜。這里列出了常見的的一些讓你程序crash 的運行時錯誤。
    發(fā)表于 03-12 16:20 ?16次下載
    Python新手<b class='flag-5'>經(jīng)常會</b>犯<b class='flag-5'>那些</b><b class='flag-5'>錯誤</b>

    51單片機和52單片機區(qū)別是什么?51仿真器有必要買嗎?

    我們在開發(fā)單片機程序的時候,經(jīng)常會碰到編譯沒有錯誤程序代碼反復的檢查,但就是找不到問題所在,不知道問題到底
    發(fā)表于 11-12 10:36 ?10次下載
    51<b class='flag-5'>單片機</b>和52<b class='flag-5'>單片機</b>區(qū)別是什么?51仿真器有必要買嗎?

    單片機初學者編程經(jīng)常會碰到的問題及處理辦法

    在剛開始接觸單片機學習的時候,尤其是C語言基礎比較薄弱的老鐵們,經(jīng)常會碰到很多比較低級的錯誤,程序編譯錯誤一大堆,但不知道如何解決!一、
    發(fā)表于 11-13 14:51 ?9次下載
    <b class='flag-5'>單片機</b>初學者編程<b class='flag-5'>經(jīng)常會</b>碰到的問題及處理辦法

    單片機BootLoader的通用實現(xiàn)方式(備份升級,永不掛機)

    單片機BootLoader的通用實現(xiàn)方式(備份升級,永不掛機)背景介紹實現(xiàn)方式背景介紹當我們在進行Linux下進行C語言程序開發(fā)時,由于C語言指針和內存的靈活性,經(jīng)常會出現(xiàn)
    發(fā)表于 11-26 15:21 ?32次下載
    <b class='flag-5'>單片機</b>BootLoader的通用實現(xiàn)方式(備份升級,永不掛機)

    使用GD芯片的AD采樣,經(jīng)常會出現(xiàn)AD值為0

    在嵌入式開發(fā)的路上經(jīng)常會遇到一些奇怪的問題。記錄下慢慢積累。有一次在做一個電機堵轉保護的功能,是用AD采樣來實時采集 電機驅動芯片的電流,超過5A時將電機強行關閉并限制相應功能,采樣電阻為0.05歐
    發(fā)表于 12-20 19:02 ?12次下載
    使用GD芯片的AD采樣,<b class='flag-5'>經(jīng)常會出現(xiàn)</b>AD值為0