当前位置:首页 > 公众号精选 > 嵌入式客栈
[导读]关注、星标嵌入式客栈,精彩及时送达[导读]大家好,我是逸珺。今天来分享一下,之前项目中使用FreeRTOS搭建的Event-Driven事件驱动框架。什么是Event-Driven?Event-DrivenEvent在计算机编程方法中,是一种广为使用的编程范式。比如Windows...

关注、星标嵌入式客栈,精彩及时送达[导读] 大家好,我是逸珺。

今天来分享一下,之前项目中使用FreeRTOS搭建的Event-Driven事件驱动框架。

什么是Event-Driven?

Event-DrivenEvent在计算机编程方法中,是一种广为使用的编程范式。比如Windows中的鼠标、键盘输入,就被Windows操作系统管理成了外部输入事件,由操作系统向不同的应用分发这些输入事件,再由用户应用程序完成相应的动作Action。在GUI编程中,这是一种主要的编程范式。

其基本结构可以用下面这张图来描述:

  • 事件生产者:对系统产生各种事件,并发送事件给系统
  • 事件分发:将外部输入的事件进行分发管理
  • 事件队列:事件分发后,对应的的事件处理者,有可能有多个事件,因此需要按先后次序依次排队处理,所以就有事件队列管理
  • 事件消费者:负责处理由事件生产者发送给它的对应事件,产生响应。事件消费者一般有一个循环程序,一直侦听事件队列,如果接收到事件,则调用相应的处理函数。

为什么推崇事件驱动?

常规的做法是程序按照固有的顺序执行,这样的编程方式,灵活性比较差。一旦需求稍有变动,可能就需要比较大的修改。在现代编程方法论中,软件的复杂度越来越大,传统过程方法不能满足复杂软件的需求,可维护性很差。用户与软件的交互体验也很差。

要回答为什么要推崇事件驱动范式,先来看看其特点:

  • 多播通信:事件生产者产生的事件可以将事件发送给多个消费者,也就是事件接收端,因此具备很强的灵活性
  • 实时传输:事件可以被事件分发者实时的传输给事件接收端。这在嵌入式应用中尤为明显
  • 异步通信:事件发布端不需要等待事件处理端处理前一个事件,发的管发,处理的管处理,这也是一种解耦设计的体现。
  • 细粒度通信:事件生产者,可以持续发送细粒度事件,而不需要将一系列事件与其业务逻辑关联,不需要聚合处理。
通过上面简要的总结其特征,再来看看为什么这个范式比较好:

  • 敏捷性:敏捷性是指应对系统外部需求的快速变化的响应能力。在事件驱动编程范式中,功能域是松散耦合的。这可确保发生在一个组件上的更改不会影响系统中的其他组件。因此,事件驱动编程范式提供的敏捷程度很高。
  • 易于部署:在事件驱动编程范式中,组件是松散耦合的。这在嵌入式Linux多应用程序组成的系统比较常见,在单片机中体现不出来。
  • 可测试性:事件驱动编程范式中单元测试难度适中,因为它需要特殊的测试客户端和测试工具来生成测试所需的事件。需要考虑其他因素,例如跨功能域的交互顺序。事件的组合和交互的顺序在系统行为中起着关键作用,需要成为测试的关键考虑因素。
  • 性能:事件驱动编程范式能够并行执行异步操作。这带来更好性能,而不管消息排队和出队所涉及的时间延迟如何。
  • 可扩展性:由于组件的高度解耦特性,事件驱动编程范式提供了高度的可扩展性。
  • 易于开发:由于该模式的异步性质,使用该模式的开发难度较低。

FreeRTOS搭事件驱动框架

FreeRTOS的Queue提供了任务到任务、任务到中断、中断到任务、中断到任务间的通讯机制。关于FreeRTOS队列本身应如何使用的细节,这里不作展开。

假定Task0需要处理这样一些事件,可以定义如下枚举:

代码如下:

typedef enum  {
    TASK0_EVENT_0,
    TASK0_EVENT_1,
    TASK0_EVENT_2
    .....
} Task0EventType;
typedef struct Task0Event_t {
    Task0EventType  type;
    union {
       float para1;
       int  para2;
       bool on;
       struct {
         xxx;
       }xxx;
    } params;    
} Task0Event;
定义一个联合params放在Task0Event内,可以使事件发送附加信息的能力,使用union则可以考虑到不同的事件发送方需要传送的附加信息不一样的需求,比如有的中断需要发送开关量信息,有的甚至可能是一条报文或者很多信息。

将Task0的任务循环写成下面这样的形式:

xQueueHandle  task0_queue;
//假定每10毫秒循环一次
#define TASK0_INTERVAL_MS           10 

void task0_main(void)
{   
   Task0Event event;
   if(xQueueReceive(task0_queue,
本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

(全球TMT2023年8月1日讯)7月27日,黑芝麻智能RTOS Microkernel产品获得DEKRA德凯颁发的ASIL D功能安全产品认证。本次认证通过标志着黑芝麻智能可以为客户提供一款高实时性、高安全性的本土操...

关键字: KERNEL MICRO RTOS 智能汽车

(全球TMT2022年11月9日讯)近日,DEKRA德凯为黑芝麻智能科技颁发ISO 26262:2018 ASIL D功能安全流程认证证书,标志着黑芝麻智能科技建立起了符合功能安全最高等级ASIL D级别的车规芯片开发...

关键字: 智能科技 ASIL ISO RTOS

有深入理解RTOS原理,或阅读过RTOS源码的同学应该知道:RTOS实现任务间通信通常是由一系列指针进行操作实现的。

关键字: RTOS 指针 数组

这次我成功将妹子约到了公司附近的咖啡馆,继续探讨RTOS的heap的技术特点。当我把准备好的数据和动图展示在她面前,她立马激动起来了。

关键字: RTOS heap FreeRTOS

很多RTOS之所以可以用于资源很少的单片机,是因为它们可以配置,一般可以使用宏定义来选择需要的功能,而裁剪掉不必要的功能,以减少对硬件的资源占用。

关键字: RTOS 单片机

处理特定任务的单片机可减轻主单片机或微处理器的任务和工作负荷,从而有助于简化各种应用的设计流程。

关键字: Microchip 单片机 RTOS

关注星标公众号,不错过精彩内容作者|strongerHuang微信公众号 | 嵌入式专栏不知道大家有没有做过低功耗产品?低功耗产品看似很简单,其实,要做好一款低功耗产品,特别是做到超低功耗,难度相对更高。今天就来讲讲在R...

关键字: RTOS 低功耗设计 单片机 CPU

关注星标公众号,不错过精彩内容作者|strongerHuang微信公众号 | 嵌入式专栏不知道大家有没有做过低功耗产品?低功耗产品看似很简单,其实,要做好一款低功耗产品,特别是做到超低功耗,难度相对更高。今天就来讲讲在R...

关键字: RTOS 低功耗设计

星标「嵌入式大杂烩」,一起进步!作者|strongerHuang微信公众号|嵌入式专栏经常在交流群都会看到有些小伙伴在问:**资料、**文档、**源码在哪里下载?资料、文档、源码在哪里找?很多初学小白,找资料、文档、源码...

关键字: RTOS 开源

AzureRTOS使资源受限的设备能够连接到微软的AzureIoT,这是全球领先的IoT生态系统之一。AzureRTOS为企业级应用程序(如航空电子设备、医疗设备、运输和工业控制)提供理想的软件开发平台而闻名,然而,其设...

关键字: RTOS 硬件 物联网设备
关闭
关闭