3年的MCU工程师就写出这样的代码?(3年的mcu工程师就写出这样的代码了)

北软失效分析赵工 半导体工程师 2022-03-26 09:18

今天分享的文章,主要给那些没有软件设计思想、初级的MCU软件工程师看的。

随着目前MCU的各方面性能显著提升,一些以MCU为控制中心的嵌入式系统也是越来越复杂,毫无软件设计理念的代码,真的是拖累单片机,所以对每个MCU软件工程师在软件设计等方面的要求也将越来越高。

年的MCU工程师就写出这样的代码?(3年的mcu工程师就写出这样的代码了)"

本文利用一个实际发生的例子,对入行的初级软件工程师提一些软件设计上的建议,并分享了一些经常走的弯路,希望可以帮到大家。

这篇文章我没有谈编程的规范性的东西,如果你想让自己的程序文件代码更加直观、看起来美观、可读性强,推荐学习一下全面的编程规范,比如网络上广为流传的,华为“C语言编程规范”。本文主要想说一说,当我们的单片机遇到多个模块的数据需要处理,类似于“多任务”时应该怎么去思考和处理?

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

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

当然,此过程我并没有过多的干涉,系统也没有经过非常严格的测试,结果发现读卡的时候不能处理触摸屏,播放语音的时候不能处理读卡,语音播放不能打断或者跳跃,反正就是所有事件必须一个一个按部就班的来,一旦操作错误,就需要多次执行、等待,甚至重新来过。

一个工作3年多的工程师怎么会把产品做成这样呢?思来想去不应该呀,是不是程序哪里出了问题 ? 解决问题的最好办法就是评审代码,来review代码瞧瞧。

不看不知道,一看吓一跳!整个的程序是没有逻辑的,一条线就往下写,这不正是当年在学校刚做第一个项目的代码吗?

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

从代码上可以看出这个工程师基本上对于自己设计的产品没有任何软件上的设计可言,也很少去吸收一些优秀的代码和思想,对自己开发的程序在产品上的具体表现也不敏感,更被说对RTOS的学习和理解了。

他犯了几个在程序开发过程中比较忌讳的错误:

1、delay(死等)这类函数应该只在实验室验证某个功能过程中用到,或许是在一些初始化时序使用到,而不会用来控制整个的程序运行架构,在实际的产品开发时无论是主循环while中,还是其调用的函数中,亦或是中断服务程序中几乎是不可能看到的。

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

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

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

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

下面提出我的建议和想法,首先他这里是裸机开发,所以就不谈RTOS方面的设计建议了,仅仅只是针对前后台架构。

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。我觉得,不管你所做的项目有没有用到RTOS,平时都需要玩玩RTOS,对该观点的理解会有帮助。

来源:21ic电子网

年的MCU工程师就写出这样的代码?(3年的mcu工程师就写出这样的代码了)"

半导体工程师

半导体经验分享,半导体成果交流,半导体信息发布。半导体行业动态,半导体从业者职业规划,芯片工程师成长历程。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年5月19日 下午8:22
下一篇 2024年5月19日 下午8:35

相关推荐

  • 现代管理科学方法在混合所有制企业基层党建中的探索与实践(现代科学管理中最为重要的方法是)

    ——以“杨三角”理论为例 报送单位 / 上汽通用五菱汽车股份有限公司党委 【摘要】本文旨在通过探索如何创造性地借鉴和使用现代管理科学理论方法用来指导企业基层党组织建设的实践,以杨国…

    科研百科 2024年7月3日
    100
  • 应急预案编制与管理随堂测试

    应急预案编制与管理随堂测试的重要性 在现代社会,意外事故和突发事件频繁发生,如何有效地应对这些事件对人们的生命安全和财产安全至关重要。因此,应急预案编制与管理随堂测试在保障公共安全…

    科研百科 2024年11月6日
    0
  • 新三届老师可以当大队辅导员吗

    新三届老师可以当大队辅导员吗新三届老师可以当大队辅导员吗首届学生成功成才的背后,肯定是同学的努力和师长的智慧和技巧,让老师们大踏步前进,肯定是咱们老师的教诲与学生们成长道路上的永不…

    科研百科 2024年11月26日
    1
  • 青海省五方面推进农牧领域保护生态环境

      党的十八大以来,习近平总书记先后11次对青海生态环境保护作出重要批示指示,提出了“四个扎扎实实”重大要求,强调“扎扎实实推进生态环境保护&r…

    科研百科 2022年5月17日
    304
  • 农业专家推荐团队的推荐信

    尊敬的先生/女士: 我写信是为了推荐我们农业专家推荐团队。我们团队由一群经验丰富的农业专家组成,他们都有着丰富的经验和专业知识,能够为您提供最优质的农业服务。 我们的团队是由一群充…

    科研百科 2024年10月13日
    6
  • 编制工程进度计划的软件

    编制工程进度计划的软件 随着工程的进展,进度计划变得越来越重要。通过使用软件,我们可以轻松地编制和跟踪进度计划,确保项目按时完成。本文将介绍一种常用的软件,用于编制工程进度计划,即…

    科研百科 2024年9月1日
    37
  • 用友畅捷通等管理软件遭勒索软件攻击(用友软件畅捷通官网)

    南方财经全媒体 记者吴立洋 实习生吴峰 北京报道 近日,多个社交媒体以及安全技术社区均有用户称遭遇“.locked”后缀勒索病毒攻击,计算机文件被病毒加密,用户“中招”后,需支付0…

    科研百科 2022年11月17日
    237
  • 新疆农科院李青军简介

    新疆农科院李青军简介 新疆农科院李青军是一位杰出的农学家,他在新疆农业领域做出了杰出的贡献。他于1963年出生于新疆伊犁地区,曾在苏联学习农业科学,后回国加入新疆农科院。 李青军在…

    科研百科 2024年10月16日
    3
  • 出入库 管理软件

    出入库管理软件: 出入库管理软件是一种专门用于管理库存物品的软件,可以帮助企业更好地管理他们的库存,提高生产效率,减少库存浪费和成本。 使用出入库管理软件可以让用户轻松地跟踪库存水…

    科研百科 2025年1月3日
    0
  • 第三方项目管理

    第三方项目管理:从概念到应用 随着现代项目管理的日益复杂和多元化,第三方项目管理逐渐成为一种新兴的项目管理方法。这种方法不受组织内部项目管理方法的限制,而是依靠外部专业项目管理公司…

    科研百科 2024年9月15日
    52