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

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

3天内不再提示

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

Q4MP_gh_c472c21 来源:嵌入式在左C语言在右 作者:嵌入式在左C语言在 2022-03-12 08:36 次阅读

0、前言

嵌入式软件开发,包括单片机开发中,软件架构对于开发人员是一个必须认真考虑的问题。软件架构对于系统整体的稳定性和可靠性是非常重要的,一个合适的软件架构不仅结构清晰,并且便于开发。

我相信在嵌入式单片机软件开发的初期大多数开发者采用的都是简单的前后台顺序执行架构(我就是这样的)。

在嵌入式软件开发中,程序架构主要分为三种,本篇文章将对这三种程序架构做出详解。

1、软件架构存在的意义

可以说一个好的程序架构,是一个有经验的工程师和一个初学者的分水岭。 软件架构对于开发人员是友好的,你希望先执行什么任务后执行什么任务,或者这一个时间点执行什么任务下一个执行什么任务,又或者什么事件会同步到某个任务等等,在不同的软件架构下,解决上述问题的具体方法都是有所区别的。 软件架构对开发者最大的帮助是: 帮助开发者掌控整个工程的框架,当你熟练使用其中某一个程序架构后,对于系统中出现的bug你一定能够快速的定位并解决。 当然,我建议要根据需要选择合适的软件架构进行开发,具体原因在文章后面会进行介绍。

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

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

顺序执行的前后台系统

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

c5e3ae5c-5567-11ec-b2e9-dac502259ad0.png

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

c5f3ccec-5567-11ec-b2e9-dac502259ad0.png

顺序执行前后台系统的中断服务函数 这种架构的优点是使用简单易于理解,而缺点是每个任务所占的CPU时间过长的话,会导致程序的实时性能差,就比如按键的检测等。

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

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

c604e720-5567-11ec-b2e9-dac502259ad0.png

时间片轮询系统的主函数

c6133e56-5567-11ec-b2e9-dac502259ad0.png

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

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

多任务操作系统

操作系统的本身是一个比较复杂的东西,任务的管理和调度实现的底层是很复杂和困难的。但是呢,我们一般都是把操作系统本身作为一个工具一个平台,我们的目的是使用它的功能而不是开发一个操作系统。

我使用过ucosfreertos小型的实时操作系统,也使用过Linux大型的操作系统,有了操作系统,不管是对于程序的稳定性和开发的效率都会好很多。我们在使用操作系统的时候更多的需要去学习和理解它的一些调度和通信的方式。

实际上真正能使用操作系统的人并不多,反而是跑裸机的占大多数,这也和产品的具体要求有关,很多简单的系统只需要裸机即可满足。

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

c62247e8-5567-11ec-b2e9-dac502259ad0.png

freertos多任务系统中主函数

c6317b14-5567-11ec-b2e9-dac502259ad0.png

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

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

我使用过多种不同MCU做项目开发,例如:STM32、STC15、新唐等,也接触过复杂的设计需求,例如:车载智能系统和智能家居,跑过操作系统ucos、freertos和Linux等等,在回到裸机开发时,就会不然而然的去思考完整系统的软件架构的设计问题,相信在读者中开发裸机的也占大多数。 我认为没有最好的软件架构(程序架构),而是只有最合适的。因为在不同的应用场景中适合采用不同的程序设计,而单纯的去比较哪种程序架构是最好的没有什么实际的意义。 那接下来我们来对具体的应用场景进行分析,在一些逻辑清晰功能单一的系统中就很适合选择顺序执行的前后台架构,这个软件架构往往能够满足我们大部分的需求,比如电饭煲、电磁炉和声控灯泡等; 而在一些资源缺乏的单片机并且对系统可靠性要求较高的情况下非常适合,因为这种方法的系统耗费比较小,只是牺牲了一个定时器而已,但是选择此种程序架构需要我们对时间片进行深思熟虑的划分; 最后,在一些功能复杂,逻辑控制较为困难的系统中就适合选择多任务操作系统,比如视频监控系统、无人机等等应用场景。 作为一名嵌入式软件工程师,掌握这三种软件架构是非常有必要的,它们可以让我们在设计程序时拥有更多的选择和思考,而每一种不同的程序架构都具备它自己的优势与不足,这需要我们去用心实践方可体会到它的奥妙。

原文标题:详解嵌入式开发中的3种程序架构

文章出处:【微信公众号:嵌入式ARM】欢迎添加关注!文章转载请注明出处。

审核编辑:汤梓红

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

    关注

    6002

    文章

    43990

    浏览量

    621019
  • 嵌入式
    +关注

    关注

    4984

    文章

    18300

    浏览量

    288730
  • 程序
    +关注

    关注

    114

    文章

    3631

    浏览量

    79573

原文标题:详解嵌入式开发中的3种程序架构

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    ARM架构核心板三种Form Factor之比较

    ARM架构核心板三种FormFactor之比较文 By易江春水国际上,在ARM核心板领域,最为常见的三种Form Factor 分别是SMARC,Qseven, Apalis, 分别有不同的厂家在
    发表于 09-28 10:35

    三种主流芯片架构

    三种主流芯片架构简单比较三种主流芯片架构  1. ARM ARM是高级精简指令集的简称(Advanced RISC Machine),它是一个32位的精简指令集
    发表于 08-14 10:11

    关于三种不同的ADC驱动器架构会有什么区别?

    有没有人讲解一下三种不同的ADC驱动器架构:单到单、单端到差动和差动到差动?
    发表于 04-07 06:55

    介绍三种视频数字接口的标准

    本文逐一介绍三种视频数字接口的标准。
    发表于 06-03 06:24

    单片机大致应用程序架构三种

    转载----在工作中经过摸索实验,总结出单片机大致应用程序架构三种:1. 简单的前后台顺序执行程序,这类写法是大多数人使用的方法,不需用思考程序
    发表于 07-21 08:50

    STM32的三种复位类型

    最近在项目的时候需要判别STM32的复位类型,网上这部分资料也有许多大神进行总结。但是感觉不是特别深入,因此,小编参考参考了STM32的参考手册进行详细总结了一下。1、STM32的三种复位类型分别为
    发表于 08-02 06:32

    LwIP协议栈开发嵌入式网络的三种方法有何关系

    服务器端通信为例,分析三种方法以及之间的关系,着重介绍基于raw API的应用程序设计。 LwIP协议栈开发嵌入式网络的三种方法分析 摘要轻量级的TCP/IP协议栈LwIP,提供了
    发表于 08-05 07:55

    算法的三种结构介绍

    嵌入式学习日记2018.11.62018.11.16理论学习阶段计算机科学导论(原书第二版)第8章 算法学到的新知识1算法的三种结构:顺序、判断(选择)和重复(循环)2常用的算法:求和、乘积、找最小
    发表于 11-08 07:12

    STM32的三种开发方式分享

    STM32的三种开发方式通常新手在入门STM32的时候,首先都要先选择一要用的开发方式,不同的开发方式会导致你编程的架构是完全不一样的。一般大多数都会选用标准库和HAL库,而极少部分人会...
    发表于 12-01 07:59

    STM32的三种boot模式介绍

    浅识STM32的三种boot模式文章目录浅识STM32的三种boot模式任务摘要一、认识boot1.三种BOOT模式介绍2.开发BOOT模式选择3.STM32
    发表于 12-10 07:46

    STM32的三种Boot模式的差异

    :STM32三种BOOT模式介绍.启动,一般来说就是指我们下好程序后,重启芯片时,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存。用户可以通过设置BOOT1和BOOT0引脚的状态,来选择在复位后的启动模式。内存类型简介主闪
    发表于 12-20 07:54

    单片机三种常用的软件架构

    一个合适的软件架构不仅结构清晰,而且可以便于开发与维护。便于帮助开发者把握整个工程的框架三种常用的软件架构:1.顺序执行的前后台系统2.时间片轮询系统3.多任务操作系统顺序执行的前后台系统程序
    发表于 01-07 08:29

    介绍一下引脚的三种状态

    介绍一下引脚的三种状态
    发表于 01-14 07:12

    记录三种DMA模式

    串口模式实现有三种1.普通模式:在主函数中接收函数2.中断模式:产生的不影响主程序运行3. DMA模式:与主函数互不影响,独立运行本文记录三种DMA模式。
    发表于 02-28 07:54

    深入介绍嵌入式开发中三种不同的程序架构

    三种常用的软件架构有:顺序执行的前后台系统、时间片轮询系统和多任务操作系统:STM32单片机开发中的RTOS。为了让大家有一个更为清晰的认识,我分别用三种软件架构对一个实例进行
    的头像 发表于 05-24 16:02 1373次阅读