实现一个简单的事件驱动处理框架

简介: 实现一个简单的事件驱动处理框架

事件驱动框架允许程序处理外部事件,如网络连接、文件I/O、超时和信号。事件驱动框架可以让程序通过回调函数处理不同的事件,回调函数可以在事件触发时立即被调用。


要实现一个简单事件驱动框架,首先需要创建一个事件处理函数,它是根据发生的不同事件调用不同的回调函数。然后,我们需要编写代码来注册事件的回调函数,即当某个事件发生时就要调用该回调函数。


直接开干:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <pthread.h>
//定义事件类型
typedef enum EventType_t
{
    EVENT_TEST_A = 0,
    EVENT_TEST_B,
    EVENT_TEST_C,
    EVENT_ALL_NUM
}EventType_t;
//定义事件处理函数类型
typedef void (*EventHandler_t)(EventType_t type, void *pArg);
//定义事件对象
typedef struct Event_t
{
    EventType_t type;
    EventHandler_t handler;
    void *pArg;
}Event_t;
//事件列表
Event_t EventList[EVENT_ALL_NUM] = {0};
//注册事件并将事件以及事件处理函数等添加到事件列表中
void RegisterEvent(EventType_t type, EventHandler_t handler, void *pArg)
{
    if (type >= EVENT_ALL_NUM)
    {
        printf("Invalid event type!\n");
        return;
    }
    EventList[type].type = type;
    EventList[type].handler = handler;
    EventList[type].pArg = pArg;
}
//根据具体的某个事件调用对应的事件触发函数
void TriggerEvent(EventType_t type)
{
    if (type >= EVENT_ALL_NUM)
    {
        printf("Invalid event type!\n");
        return;
    }
    if (EventList[type].handler != NULL)
    {
        EventList[type].handler(type, EventList[type].pArg);
    }
}
//对应事件A的处理函数
void HandlerEventTestA(EventType_t type, void *pArg)
{
    printf("HandlerEventTestA is called!\n");
}
//对应事件B的处理函数
void HandlerEventTestB(EventType_t type, void *pArg)
{
    printf("HandlerEventTestB is called!\n");
}
void *ThreadHandler(void *Arg)
{
    while(1)
    {
       //触发事件A
       TriggerEvent(EVENT_TEST_A);
       usleep(1000*1000);
       //触发事件B
       TriggerEvent(EVENT_TEST_B);
       usleep(1000*1000);
    }
}
int main(void)
{
    pthread_t Thread;
    //注册事件A & B
    RegisterEvent(EVENT_TEST_A, HandlerEventTestA, NULL);
    RegisterEvent(EVENT_TEST_B, HandlerEventTestB, NULL);
    pthread_create(&Thread, NULL, ThreadHandler, NULL);
    pthread_detach(Thread);
    while(1)
    {
      usleep(2000 * 10);
    }
    return 0;
}

编译程序:

gcc test.c -o test -lpthread

运行结果:

640.png

往期精彩

分享GitHub上一些嵌入式相关的高星开源项目


开源:AliOS_Things_Developer_Kit开发板复活计划


一种可用于单片机的中断高效处理与事件机制方法


开源按键组件MultiButton支持菜单操作(事件驱动型)


手把手教你在STM32上实现OLED视频播放(很简单也很硬很肝!)


回调函数的注册机制为什么会在嵌入式固件开发中应用如此广泛?


一些值得被定义为常用C语言头文件库的漂亮宏定义(值得收藏,以备使用参考)


基于事件型表驱动法菜单框架之小熊派简易气体探测器实战项目开发(中)

目录
相关文章
|
3月前
|
消息中间件 监控 测试技术
事件驱动架构是一种编程范式
【10月更文挑战第7天】事件驱动架构是一种编程范式
121 65
|
3月前
|
传感器 物联网 数据挖掘
事件驱动模型
【10月更文挑战第30天】
39 5
|
3月前
|
存储 设计模式 监控
事件驱动架构的实现方式?
【10月更文挑战第7天】事件驱动架构的实现方式?
64 7
|
8月前
|
监控 数据处理
事件驱动架构的优势
事件驱动架构的优势
|
4月前
|
设计模式 开发框架 前端开发
在开发框架中实现事件驱动架构
【9月更文挑战第2天】事件驱动架构(EDA)通过事件机制让组件间解耦交互,适用于动态扩展和高响应性的系统。本文提供一个基于Beego框架实现事件驱动的示例,通过事件管理器注册和触发事件,实现用户注册和登录时的不同处理逻辑,展示了其在Web应用中的灵活性和高效性。
97 5
|
7月前
|
消息中间件 传感器 Cloud Native
事件驱动作为分布式异步服务架构
【6月更文挑战第25天】本文介绍事件驱动架构(EDA)是异步分布式设计的关键模式,适用于高扩展性需求。EDA提升服务韧性,支持CQRS、数据通知、开放式接口和事件流处理。然而,其脆弱性包括组件控制、数据交换、逻辑关系复杂性、潜在死循环和高并发挑战。EDA在云原生环境,如Serverless,中尤其适用。
230 2
事件驱动作为分布式异步服务架构
|
7月前
|
监控 网络协议 安全
事件驱动的反应堆模式
【6月更文挑战第22天】这是一个关于面向对象封装的事件驱动端口监控服务的文章摘要。文中还以一个分布式日志系统为例,展示了如何通过客户端/服务器架构处理并发I/O。后续部分比较了不同的多路I/O解决方案,并预告了反应堆的详细设计和实现。
90 5
事件驱动的反应堆模式
|
7月前
|
存储 数据处理 数据库
理解在服务架构中的事件驱动
【6月更文挑战第14天】网络架构和软件设计常基于ISO七层模型和三层应用架构,强调数据处理的重要性。事件驱动架构(EDA)以事件为中心,改变传统设计方式,解决系统问题。事件是触发通知或状态变化的操作,如用户下单。EDA适用于微服务通信、工作流程自动化、SaaS集成和基础设施自动化等场景,提高系统敏捷性和可扩展性。然而,EDA并非万能,需根据需求选择合适的设计方案。
201 1
理解在服务架构中的事件驱动
|
7月前
|
设计模式 监控 中间件
中间件事件驱动
【6月更文挑战第18天】
68 3
|
6月前
|
消息中间件 设计模式 监控
中间件发布订阅事件驱动架构
【7月更文挑战第2天】
101 1