嵌入式框架设计

1. 数据的通信

1.1 基于环形队列的数据缓冲

嵌入式系统将需要发送的数据写入队列,而上位机则从队列中读取数据。由于环形队列的特性,可以实现先进先出的数据传输机制,保证数据的顺序性和完整性。这种通信方式适用于需要存储和传输大量数据的场景,能够有效地解耦嵌入式系统和上位机之间的数据传输,提高通信效率。

注意:

1.在多线程的队列读写,应在读写时加锁来保护。

2.环形队列读的速度慢于写时,一旦写的地址到达了读的地址时,队列将被清空。

  • 优点:保持了数据的顺序性和完整性,有效解耦了生产者和消费者,实现了解耦的通信方式。
  • 适用场景:适用于需要高效地存储和传输大量数据的场景,能够提高通信效率和保证数据传输的顺序性。

C程序设计:环形队列_环形队列c实现-CSDN博客

1.2 基于超时机制的数据收发模式

嵌入式系统和上位机之间通过设定超时时间来进行数据的发送和接收。嵌入式系统在发送数据后等待上位机的回复,在设定的超时时间内如果没有收到回复,则进行相应的处理,比如重新发送数据或者进行错误处理。这种通信方式能够有效地处理因网络或其他原因导致的数据丢失或超时的情况,提高通信的可靠性和稳定性。

  • 优点:能够有效处理数据传输过程中出现的超时情况,提高通信的可靠性和稳定性。
  • 适用场景:适用于对通信过程中的及时性要求较高的场景,能够及时处理因网络或其他原因导致的数据丢失或超时的情况。

2. 任务调度框架的设计

2.1 状态机+链表事件(适用与单线程框架)

任务之间的切换使用状态机来实现, 外部消息使用事件的方式来下发到任务中。

流程:主线程中:

系统消息事件出队,获取当前最新的消息(任务切换,数据事件,中断事件,无事件等)。

然后用当前运行的状态中的任务去处理这个事件。

更新当前的状态。

根据新的状态执行固定的task.

C程序设计:状态机_状态机编程-CSDN博客

C程序设计:基于循环双向链表的事件管理器_事件链表-CSDN博客

2.2 基于状态机的多任务调度框架(多线程)

类似上诉方法,只是状态任务都设计为单独线程,使用消息队列来进行消息的传递和任务的切换。

2.3 基于c++设计模式

C++ 程序设计:四大模式(工厂+装饰+策略+观察者)_c++四种模式-CSDN博客

3.数据维护的设计

3.1 运行时易变的参数

例如:

1.当前的运行模式。

2.当前的模板。

3.当前的算法选择等。

4.时间。

5.日志。

3.2 系统配置参数,可通过上位机修改的。

例如:SN号等,一些加密等级,通信方式等。

3.3 系统配置参数,不可修改的。

例如:固定的设备版本号,设备型号等。

3.4 modify

合理的利用modify维护在程序中,容易改变的变量,保证程序中的变量不会发生突变。

通过这种方式,我们可以降低程序的耦合性,提高程序的可维护性和可拓展性。当需要对程序进行调整或优化时,只需要修改这些 modify 变量的值,而不用改动大量代码。这样做有助于降低代码修改的风险,并提高代码的可读性和可维护性。

4.OTA的设计

单片机中实现bootloader功能_单片机bootloader-CSDN博客

5.日志系统的设计

freeRTOS:基于(队列+线程)的日志系统设计-CSDN博客

6.flash擦写平衡的设计

C程序设计:基于双向链表的flash磨损平衡算法_flash均衡擦写算法 c语言-CSDN博客

7.内存管理设计

单片机实现动态内存管理_单片机内存池设计-CSDN博客

相关推荐
上海云盾-小余5 小时前
CC 攻击与 DDoS 联动防护:如何构建一体化流量清洗架构
网络·安全·游戏·架构·ddos
张张123y6 小时前
#Transformer架构与微调技术深度解析
深度学习·架构·transformer
SuniaWang6 小时前
《Spring AI + 大模型全栈实战》学习手册系列· 专题二:《Milvus 向量数据库:从零开始搭建 RAG 系统的核心组件》
java·人工智能·分布式·后端·spring·架构·typescript
无忧智库6 小时前
破局与重构:大型企业级数字化业务运营平台的深度解构与演进之路(WORD)
大数据·架构
C澒6 小时前
微前端容器标准化 —— 公共能力篇:通用请求
前端·架构
七夜zippoe6 小时前
OpenClaw Gateway 服务:启动、停止、监控
微服务·架构·gateway·监控·openclaw
⑩-6 小时前
RabbitMQ 架构和工作原理?RabbitMQ 延迟队列如何实现?
java·分布式·架构·rabbitmq
殷紫川7 小时前
RocketMQ 两大核心特性深度拆解:事务消息与延时消息,从原理到实战全打通
架构·rocketmq
殷紫川7 小时前
Elasticsearch 核心命脉:倒排索引、分片机制与全链路高性能调优实战
elasticsearch·架构
九河云7 小时前
边缘计算与云协同:5G时代企业IT架构的新布局
大数据·5g·架构·边缘计算·数字化转型