详解嵌入式开发中的三种程序架构

前言

在嵌入式软件开发,包括单片机开发中,软件架构对于开发人员是一个必须认真考虑的问题。软件架构对于系统整体的稳定性和可靠性是非常重要的,一个合适的软件架构不仅结构清晰,并且便于开发。我相信在嵌入式或单片机软件开发的初期大多数开发者采用的都是简单的前后台顺序执行架构(我就是这样的)。在嵌入式软件开发中,程序架构主要分为三种,本篇文章将对这三种程序架构做出详解。

1、软件架构存在的意义

可以说一个好的程序架构,是一个有经验的工程师和一个初学者的分水岭。软件架构对于开发人员是友好的,你希望先执行什么任务后执行什么任务,或者这一个时间点执行什么任务下一个执行什么任务,又或者什么事件会同步到某个任务等等,在不同的软件架构下,解决上述问题的具体方法都是有所区别的。

软件架构对开发者最大的帮助是:帮助开发者掌控整个工程的框架,当你熟练使用其中某一个程序架构后,对于系统中出现的bug你一定能够快速的定位并解决。当然,我建议要根据需要选择合适的软件架构进行开发,具体原因在文章后面会进行介绍。

2、深入介绍三种不同的程序架构

三种常用的软件架构有:顺序执行的前后台系统、时间片轮询系统和多任务操作系统。为了让大家有一个更为清晰的认识,我分别用三种软件架构对一个实例进行介绍说明。这个实例如下:它有4个任务,这4个任务为按键扫描、声光报警、显示屏刷新和超声波测距。这个实例的具体功能是通过按键设置测量距离的阈值,当测距距离低于设置的阈值时,触发声光报警并且将测量距离实时显示在显示屏上(这个应用是汽车倒车雷达的具体体现)。

  • 2.1顺序执行的前后台系统

在顺序执行的前后台系统中,我会把键盘扫描用查询的方式放在while(1)中,而显示屏刷新和超声波测距使用中断,在中断服务函数中获取测量距离后进行显示,在主函数的循环中进行按键的检测,声光处理也放在主循环中。这样整个程序就以变量标志的同步方式在主循环和后台中断中执行,对应的程序代码如图所示:

顺序执行前后台系统的主函数

顺序执行前后台系统的中断服务函数

这种架构的优点是使用简单易于理解,而缺点是每个任务所占的CPU时间过长的话,会导致程序的实时性能差,就比如按键的检测等。

  • 2.2时间片轮询系统和多任务操作系统

时间片轮询法实际上通常出现在操作系统中,也就是说他属于操作系统,但在这里所说的是基于前后台系统的时间片轮询。时间片轮询法的实质其实就是选出一个定时器,没进一次定时中断对计数值进行自加,在主循环中根据这个计数值执行任务,这个计数值也就是任务轮询的时间片。在这个实例中,如果采用时间片轮询系统的话,首先选用主控芯片的任一定时器,定时器定时时间周期由我们决定,为了保证实时性和运行效率,这个值通常取10ms、30ms、50ms等,我会将按键扫描轮值值设置为20ms,因为按键抖动的时长一般为20ms,这样处理既达到了消抖的目的,又不会漏掉按键的检测;而显示屏的刷新设置为30ms,如果你觉得刷新反应慢了也可以修改这一轮询值得到改善;而超声波测距的轮询值设置为100ms,即每隔100模式触发测距一次,这个测距频率已经能够满足大多数的情况了。

程序代码如下:

时间片轮询系统的主函数

时间片轮询系统的定时器中断函数

可以看出时间片轮询法相比顺序执行还是有很大优势的,既有顺序执行法的优点,也有操作系统的部分优点。

  • 2.3多任务操作系统

操作系统的本身是一个比较复杂的东西,任务的管理和调度实现的底层是很复杂和困难的。但是呢,我们一般都是把操作系统本身作为一个工具一个平台,我们的目的是使用它的功能而不是开发一个操作系统。我使用过ucos和freertos小型的实时操作系统,也使用过Linux大型的操作系统,有了操作系统,不管是对于程序的稳定性和开发的效率都会好很多。我们在使用操作系统的时候更多的需要去学习和理解它的一些调度和通信的方式。实际上真正能使用操作系统的人并不多,反而是跑裸机的占大多数,这也和产品的具体要求有关,很多简单的系统只需要裸机即可满足。

在这里本我不过多的介绍操作系统本身,因为操作系统确实挺复杂的,下面图例中的代码是在freertos中创建按键控制LED亮灭的程序结构,大家可以对比一下:

freertos多任务系统中主函数

freertos多任务操作系统中的任务回调函数

3、如何选择合适的软件架构

我使用过多种不同MCU做项目开发,例如:STM32、STC15、新唐等,也接触过复杂的设计需求,例如:车载智能系统和智能家居,跑过操作系统ucos、freertos和Linux等等,在回到裸机开发时,就会不然而然的去思考完整系统的软件架构的设计问题,相信在读者中开发裸机的也占大多数。

我认为没有最好的软件架构(程序架构),而是只有最合适的。因为在不同的应用场景中适合采用不同的程序设计,而单纯的去比较哪种程序架构是最好的没有什么实际的意义。那接下来我们来对具体的应用场景进行分析,在一些逻辑清晰功能单一的系统中就很适合选择顺序执行的前后台架构,这个软件架构往往能够满足我们大部分的需求,比如电饭煲、电磁炉和声控灯泡等;而在一些资源缺乏的单片机并且对系统可靠性要求较高的情况下非常适合,因为这种方法的系统耗费比较小,只是牺牲了一个定时器而已,但是选择此种程序架构需要我们对时间片进行深思熟虑的划分;最后,在一些功能复杂,逻辑控制较为困难的系统中就适合选择多任务操作系统,比如视频监控系统、无人机等等应用场景。

作为一名嵌入式软件工程师,掌握这三种软件架构是非常有必要的,它们可以让我们在设计程序时拥有更多的选择和思考,而每一种不同的程序架构都具备它自己的优势与不足,这需要我们去用心实践方可体会到它的奥妙。

(0)

相关推荐

  • 自研操作系统成行业趋势,国内车控操作系统标准来了!

    导语 越来越多的企业选择自研操作系统,其中的标准谁来掌控? 在单片机时代,Autosar(AUTOmotive Open System Architecture)(汽车开放系统架构)是汽车电子领域主要 ...

  • 干货 | FreeRTOS学习笔记 ——应用场景

    去年NXP KW41大赛的时候被迫啃了一口FreeRTOS,我后来打算系统地学习一下它,再尝试应用到自己的DIY项目当中去.FreeRTOS只是众多的 RTOS (字面意思是实时操作系统)中的一种,因 ...

  • 嵌入式软件底层开发的框架陈述

    在底层代码编写中,初始的框架设计总会面临选择,针对实际的硬件使用环境,大家对于使用的软件框架有很多选择,今天我简单描述一些比较常用的架构,让大家能够理解并选择合适的架构. 总述 1. 简单的顺序执行程 ...

  • Linux:想彻底搞懂“系统调用”的底层原理?建议您别错过这篇【调用门】

    来自公众号:IOT物联网小镇 作  者:道哥,10+年嵌入式开发老兵,专注于:C/C++.嵌入式.Linux. 目录 门描述符 调用门特权级检查规则 调用门的使用过程 安装调用门 把调用门告诉用户程序 ...

  • 软件定义汽车: 迈向SOA

    迈向SOA汽车软件架构,推动软件定义汽车成为现实 "软件定义汽车"已为产业共识,且随着特斯拉率先落地"硬件为流量入口.软件为收费服务"的商业模式,由此带来了显著 ...

  • 嵌入式系统软件架构浅析

    软件架构,就是软件的结构,包含软件元素(模块构件等).外部接口及其相互关系. 1.软件架构的作用 做到嵌入式软件的代码逻辑清晰,且避免重复造轮子: 架构设计有利于软件的移植,没有架构,代码混乱,移植将 ...

  • 嵌入式开发中的三种程序构架

    关注.星标公众号,直达精彩内容 0.前言 在嵌入式软件开发,包括单片机开发中,软件架构对于开发人员是一个必须认真考虑的问题.软件架构对于系统整体的稳定性和可靠性是非常重要的,一个合适的软件架构不仅结构 ...

  • 深入浅出详解软件开发中的 6 大设计原则

    在软件开发中,前人对软件系统的设计和开发总结了一些原则和模式, 不管用什么语言做开发,都将对我们系统设计和开发提供指导意义.本文主要将总结这些常见的原则,和具体阐述意义. 开发原则 面向对象的基本原则 ...

  • 【收藏】详解供配电系统中的几种配电方案

    一.单路进线的配电方案 单路进线的配电形式 单路进线的配电方案属于点状配电方案,也是最简单的配电方案. 单路进线的配电方案仅能对负荷提供最低水平的供电可靠性,因为一旦供电中断后没有冗余电源提供第二路电 ...

  • 股权架构中的三种死局,何解?

    人的基因对人的寿命有影响,同样,企业的基因也会影响企业的寿命.人的基因如果发生异变,就会有患癌的风险.企业的基因如果出现异常,企业就无法正常运转,纠纷不断,甚至走向破产. 企业的合伙人和股权架构共同决 ...

  • 嵌入式开发中常用的几种通信接口总结

    在嵌入式系统中,板上通信接口是指用于将各种集成电路与其他外围设备交互连接的通信通路或总线. 以下内容为常用板上通信接口:包括I2C.SPI.UART.1-Wire: I2C总线 I2C总线是一种同步. ...

  • 嵌入式开发中静态代码分析工具的几种功能和用途

    当前标准的C语言编译器存在普遍只能找出代码中潜在的缺陷,而对程序方案设计并没有效. 使用静态代码分析器有助于提升固件和捕获编译器难以察觉的问题. 用于嵌入式的常见代码静态分析工具 代码静态分析工具,顾 ...

  • 行书中的三种连带形式和《怀仁集王圣教序》连带点画九种

    一.行书中的三种连带形式浅介: 1.牵丝 "牵丝"是在一笔的结束处与另一笔的开头间本无笔画,而书写时顺势连上了的细线.在行书中,经常用牵丝来联结分散的笔画,使不太联贯的笔画联贯起来,使字的结 ...

  • 详解人防工程如何施工(三)210508

    门框检验 为确保万无一失,浇灌门框墙的混凝土之前施工单位还需征得防护设备生产安装厂家技术负责人的认可,一处一处检查,一处一处认可,避免出现门打不开或不能全开的现象:另外,严格控制地面标高,在施工现场常 ...

  • 10张思维导图,详解孩子学习中的10大坏习惯!

    10张思维导图,详解孩子学习中的10大坏习惯!