OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3208|回复: 5

单片机程序开发时,常犯的错误

[复制链接]

39

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
155
金钱
155
注册时间
2016-3-30
在线时间
24 小时
发表于 2016-5-5 11:51:44 | 显示全部楼层 |阅读模式
1金钱
这里利用一个实际发生的例子,针对初级工程师经常犯的一个小错误,或者经常要走的一个弯路,做了针对性的纠正。希望可以帮到大家,文笔不好文章中有叙述不清的地方大家多多指教。
这篇文章我不是想说编程的规范性的东西,如果你想让自己的程序文件最起码直观的看起来美观、可读性强,推荐找华为的“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。
更多嵌入式咨询可加交流群277686564   QQ2905283896   电话13722663815

10671746.gif
20150626040715_38973.jpg
QQ图片20160423113845.jpg
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

46

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
233
金钱
233
注册时间
2015-10-28
在线时间
56 小时
发表于 2016-5-6 17:13:58 | 显示全部楼层
回复

使用道具 举报

3

主题

24

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
316
金钱
316
注册时间
2016-3-19
在线时间
36 小时
发表于 2016-5-6 20:02:44 | 显示全部楼层
感谢分享,虽说密密麻麻的全是字。
回复

使用道具 举报

1

主题

78

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
211
金钱
211
注册时间
2015-12-10
在线时间
49 小时
发表于 2016-5-7 00:30:27 | 显示全部楼层

1、构建一个实施多任务框架(uCOSII就足以胜任一般小型应用)及其多个任务;
2、处理好各个任务间的资源和数据同步(信号灯,互斥量,消息队列);
3、设计好处理随机事件的中断服务。

俺认为,最好的应用方式为,嵌入式前端(可以有多个)以黑模式运行,通过以太网(有线,无线)与上位机互联,上位机windows下运行主APP(GUI用户交互,数据处理,动态显示,文件记录...)。

这种方式几乎可以应对任何复杂的应用需求(这不就是基于网络互联的分布式系统吗?)
逆水行舟不进则退
回复

使用道具 举报

33

主题

984

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8054
金钱
8054
注册时间
2014-8-13
在线时间
1597 小时
发表于 2016-5-7 00:55:02 | 显示全部楼层
那个工程师根本就是个新手。

这种阻塞式的设计有可能是因为赶工或者应付,如果是应付,可以辞掉了,态度不端正。

如果是赶工,培养一下吧。

显然我不信你那个工程师做嵌入式开发有3年了,或者他从前只做硬件开发,不写程序?

如果他真的开发了3年,还写这样的程序,那么他不适合这个工作。




不知道LZ是培训机构人员还是公司一把抓的BOSS。

如果是培训机构,不做评论。
如果您是公司的BOSS,尤其是刚起步的公司,您的这种管理方式太致命了。
回复

使用道具 举报

21

主题

144

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1132
金钱
1132
注册时间
2015-7-31
在线时间
155 小时
发表于 2016-5-7 09:50:07 | 显示全部楼层
3年,我们单位一个小子,单片机干了8年了,连个定时器定时都搞不明白,这种人太多了,只是敷衍工作而已
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-10 19:04

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表