0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

单片机的程序开发经常会出现那些错误

Wildesbeast 来源:网络整理 作者:佚名 2021-01-09 10:41 次阅读

这里利用一个实际发生的例子,针对初级工程师经常犯的一个小错误,或者经常要走的一个弯路,做了针对性的纠正。希望可以帮到大家,文笔不好文章中有叙述不清的地方大家多多指教。

这篇文章我不是想说编程的规范性的东西,如果你想让自己的程序文件最起码直观的看起来美观、可读性强,推荐找华为的“C语言编程规范”。我只想说一说当我们的单片机遇到多个模块的数据需要处理,类似于“多任务”时我们应该怎么办?

背景是这样的,去年9月份开始安排一个工程师开始做电动汽车交流充电桩机械设计部分由公司机械结构部门负责。充电桩的电子部分总体上分为X个部分(用到的资源),电阻触摸屏(RS232),M1卡读写(RS232),电能计量表(RS485),语音提示(SPI),电力开关(继电器IO),通讯接口(RS485、CAN)。

工程师做的过程非常勤奋,期间也是困难重重,改了很多个版本,总算今年6月把充电桩立起来了。

咱们来验收一下吧,结果发现读卡的时候不能处理触摸屏,播放语音的时候不能处理读卡,语音播放不能打断或者跳跃,反正就是所有事件必须一个一个按部就班的来,一旦操作错误就需要多次执行、等待、甚至重新来过。

一个工作3年多的工程师怎么会把产品做成这样呢?看看程序吧!

一看不要紧,吓一跳!整个的程序是没有逻辑的,一条线就往下写……

While(1){//上电进入主程序 或 触发触摸屏//播放提示语音Delay();//等待播放完毕//读取M1卡信息Delay();//等待读卡数据返回//播放提示语音Delay();//等待播放完毕//M1卡数据交互,判定下一步操作及提示Delay();//等待数据处理完毕…………}

这里说这个工程师基本上对于自己设计的产品没有任何的整体概念,或者说对自己开发的程序用到设计上会有怎样的实际效果根本就不清楚。

他犯了几个我们在程序开发过程中最忌讳的几个问题:

1、 delay(死等)这类函数只在应该实验室验证某个功能过程中用到,在实际的产品开发时无论是主循环while中,还是其调用的函数中,亦或是中断服务程序中绝对不可以用到。

2、 产品设计的各个子模块之间的逻辑关系太强,例如:必须等待播音完毕才能读卡进入下一步操作等。

我们讲,产品设计中只有各个事件处理模块间的逻辑关系弱化,才能更加灵活的进行处理。例如:两个事件A和B,如果程序开发时将A做成B事件的必要条件,B事件的触发就必须等待A事件的发生。反之如果A事件作为B事件处理的一个特殊情况,那么程序开发起来就变得灵活很多。

3、 没有考虑到单片机本身是一个单核单任务的架构,每一个事件都会独占CPU内核,当多个任务模块同时存在时我们应该对各个事件进行区分,我们应当分情况、分事件实时性要求等区分对待。

那么针对于这样的问题,或者是遇到类似的项目我们应该如何处理呢?

我提几条建议:

1、将硬件系统区分为独立单元单独做成底层驱动函数和应用函数,并且函数正常应该有参数和返回值,其中返回值是必要的。如何衡量这类函数呢?这类函数可移植性强,只要一个.h文件和一个.c文件就可以随意放到任何工程中。例如:语音播放、M1读卡、485处理等等。

2、将1中的所有函数进行时间评估,评估点有两个。一个是函数的执行时间t,第二个是函数的周期性发生的时间T,一个最基本的条件是t 《 T,理想情况应该是t 《《 T。

3、建立一个集中逻辑处理函数,在这个函数中对1中的各个函数进行调度。这个函数发挥的作用相当于嵌入式系统中的系统调度。这种调度是整个硬件逻辑中所有事件处理的调度,它的目的是完成一个处理过程,但是绝不依赖于任意事件的必要处理过程。这样就将问题2中提到的事件间的逻辑关系弱化了,处理起来变得十分灵活,使得各个关系不在相互必要。

4、为了保证前面内容的正常实施还需要针对各类事件的周期,建立一个必要的时间管理函数,时间函数的基础一般情况下由一个内部定时器的中断来完成,中断的周期一般我们考虑5-10ms。按照实际需求将N个定时器中断定义为一个事件处理的周期TT,这个周期应该保证处理完最恶劣情况可能发生的所有t,且保证TT 《 T。

5、 这其中也有例外,一些实时性要求高的事件应当用中断完成。其中中断处理函数的处理事件应尽量短,时间要求参见2。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6036

    文章

    44555

    浏览量

    634873
  • RS485
    +关注

    关注

    39

    文章

    1157

    浏览量

    82308
  • C语言
    +关注

    关注

    180

    文章

    7604

    浏览量

    136739
收藏 人收藏

    评论

    相关推荐

    单片机程序总跑飞?小技巧帮你忙

    经常接触单片机的朋友,肯定遇到过单片机程序跑飞的问题。由于程序较为复杂,所以一旦出现跑飞的现象就
    发表于 04-02 09:58 8609次阅读

    单片机BootLoader的通用实现方式

    单片机BootLoader的通用实现方式(备份升级,永不挂机)背景介绍实现方式背景介绍当我们在进行Linux下进行C语言程序开发时,由于C语言指针和内存的灵活性,经常会出现
    发表于 07-21 06:55

    开发单片机程序时碰到编译错误

    我们在开发单片机程序的时候,经常会碰到编译没有错误程序代码反复的检查,但就是找不到问题所在,不知道问题到底
    发表于 11-18 07:30

    程序开发经常容易出现的问题汇总

    在刚开始接触单片机学习的时候,尤其是C语言基础比较薄弱的老铁们,经常会碰到很多比较低级的错误程序编译错误一大堆,但不知道如何解决!一、
    发表于 11-22 06:19

    使用GD芯片的AD采样经常会出现AD值为0是为什么?

    使用GD芯片的AD采样经常会出现AD值为0是为什么?
    发表于 02-16 07:50

    单片机的外部中断使用经常会出现那些问题应该如何解决

    通过分析51单片机外中断I/O入口的内部结构,解释了外中断不能被正常响应的原因,并提出了解决该问题的方法。
    发表于 09-09 17:26 1次下载
    <b class='flag-5'>单片机</b>的外部中断使用<b class='flag-5'>经常会出现</b><b class='flag-5'>那些</b>问题应该如何解决

    51单片机经常会出现的4点错误解决方法详细说明

    本文档的主要内容详细介绍的是51单片机经常会出现的4点错误解决方法详细说明。
    发表于 09-06 17:26 0次下载
    51<b class='flag-5'>单片机</b><b class='flag-5'>经常会出现</b>的4点<b class='flag-5'>错误</b>解决方法详细说明

    JLINK_V8固件烧写经常会碰到那些常见的错误

    本文档的主要内容详细介绍的是JLINK_V8固件烧写经常会碰到那些常见的错误
    发表于 08-16 17:32 4次下载
    JLINK_V8固件烧写<b class='flag-5'>经常会</b>碰到<b class='flag-5'>那些</b>常见的<b class='flag-5'>错误</b>

    内存经常会出现那些故障?应该如何解决

    内存对于电脑的重要性不言而喻,缺少内存,电脑将无法正常运转。如果内存发生故障,笔记本将同样产生一些令人疑惑的错误。本文中,小编将对内存可能出现的故障以及相应的解决措施予以介绍。如果你对内存具有兴趣,抑或您的电脑内存出现故障,不妨
    发表于 10-17 11:56 3772次阅读

    2246EN开卡工具和经常会出现的问题分析

    本文档的主要内容详细介绍的是2246EN开卡工具应用程序经常会出现的问题分析。
    发表于 11-23 08:00 15次下载
    2246EN开卡工具和<b class='flag-5'>经常会出现</b>的问题分析

    Python新手经常会那些错误

    当初学Python 时,想要弄懂Python 的错误信息的含义可能有点复杂。这里列出了常见的的一些让你程序crash 的运行时错误
    发表于 03-12 16:20 16次下载
    Python新手<b class='flag-5'>经常会</b>犯<b class='flag-5'>那些</b><b class='flag-5'>错误</b>

    51单片机和52单片机区别是什么?51仿真器有必要买吗?

    我们在开发单片机程序的时候,经常会碰到编译没有错误程序代码反复的检查,但就是找不到问题所在,不知道问题到底
    发表于 11-12 10:36 10次下载
    51<b class='flag-5'>单片机</b>和52<b class='flag-5'>单片机</b>区别是什么?51仿真器有必要买吗?

    单片机初学者编程经常会碰到的问题及处理办法

    在刚开始接触单片机学习的时候,尤其是C语言基础比较薄弱的老铁们,经常会碰到很多比较低级的错误程序编译错误一大堆,但不知道如何解决!一、
    发表于 11-13 14:51 9次下载
    <b class='flag-5'>单片机</b>初学者编程<b class='flag-5'>经常会</b>碰到的问题及处理办法

    单片机BootLoader的通用实现方式(备份升级,永不挂机)

    单片机BootLoader的通用实现方式(备份升级,永不挂机)背景介绍实现方式背景介绍当我们在进行Linux下进行C语言程序开发时,由于C语言指针和内存的灵活性,经常会出现
    发表于 11-26 15:21 32次下载
    <b class='flag-5'>单片机</b>BootLoader的通用实现方式(备份升级,永不挂机)

    使用GD芯片的AD采样,经常会出现AD值为0

    在嵌入式开发的路上经常会遇到一些奇怪的问题。记录下慢慢积累。有一次在做一个电机堵转保护的功能,是用AD采样来实时采集 电机驱动芯片的电流,超过5A时将电机强行关闭并限制相应功能,采样电阻为0.05欧
    发表于 12-20 19:02 12次下载
    使用GD芯片的AD采样,<b class='flag-5'>经常会出现</b>AD值为0