C 嵌入式系统设计模式 16:循环执行模式

news2025/1/2 4:43:27

本书的原著为:《Design Patterns for Embedded Systems in C ——An Embedded Software Engineering Toolkit 》,讲解的是嵌入式系统设计模式,是一本不可多得的好书。

本系列描述我对书中内容的理解。本文章描述嵌入式并发和资源管理模式之二:循环执行模式。

循环执行模式 (Cyclic Executive Pattern) 是一种 调度模式。在计算机系统中,调度模式指的是对任务、进程或线程进行调度时所采用的一种或多种特定的策略或方法。这些模式旨在优化资源利用率、提高系统性能、确保实时响应等。

循环执行模式在调度多任务时具备的优势是——简单。然而,该模式在应对紧急事件时不够灵活。尽管如此,循环执行模式确保了调度的公平性,使得所有任务都有均等的机会得以运行。虽然从响应性的视角来看,它并非最佳选择,但循环执行模式在可调度性分析方面表现出色,这个模式可以很容易的分析 可调度性

可调度性:如果一个任务集中的所有任务都能按时完成,那么这个任务集就被称为是可调度的。

具体来说,每个任务的截止时间必须大于或等于所有任务在最坏情况下执行时间的总和,再加上循环调度所产生的开销。如果我们假设每个任务的截止时间恰好等于一个完整任务执行周期的时长,那么如下所示的公式给出了任务集中可调度的必要条件:
D i ≥ ∑ j = 1 n C j + K D_{i} ≥ \sum_{j=1}^n C_{j} + K Dij=1nCj+K

其中:

  • Di 是任务 i 的截止时间
  • Cj 是任务 j 的最坏执行时间
  • K 是循环执行的开销,包括任务调用和返回的开销。

摘要

循环执行模式主要应用于两种场景:

  1. 在规模较小的嵌入式应用程序中,该模式能够支持多个任务以伪并发的方式运行,而无需引入复杂的调度程序或实时操作系统(RTOS)所带来的额外开销。
  2. 在高安全性的系统中,由于循环执行模式易于进行认证,因此它在航空电子和飞行管理系统等领域得到了广泛应用。

在循环执行模式中,调度程序采用简单的循环结构,按顺序逐个调用每个任务。每个任务实质上只是调度程序调用的一个函数,该函数在执行完毕后即返回,等待下一次被调用的机会。

问题

许多嵌入式系统是微型应用程序,它们的内存和时间限制非常严格,甚至无法承载即便是经过高度优化的微型内核 RTOS。循环执行模式为实现此目标提供了一种资源较少的方法。

模式结构

模式结构图如下所示:

在这里插入图片描述

循环执行器 包含一个名为 controlLoop() 的函数,该函数的主要职责是循环地调用每个任务线程的 run() 函数。这些 run() 函数都比较简短,一旦开始执行,它们就会一直运行到函数结束。

模式详情

抽象的循环执行线程

通过声明 run() 函数为线程提供了标准接口。循环执行器 将调用这个函数来执行任务。当函数执行完成时,循环执行器将运行列表中的下一个任务。

循环执行器

这个 包含无限循环结构,依次运行各个任务。另外,循环执行器还包含全局堆栈和静态数据,这些数据由任务或调度程序本身所需。

该模式的一种变体是 时间触发的循环执行器 。在这种变体中,循环执行器将设置并使用 循环定时器 来启动任务列表的任务。

循环定时器

循环定时器是可选的。常见的循环执行器并不使用循环定时器。如果使用循环定时器,定时器在到期时可以触发中断。或者更简单地,定时器到期时可以让 hasElapsed() 函数返回 TRUE(非零值)。随后,循环调度器会调用 start() 函数来再次启动循环定时器。

具体的循环执行线程

具体的任务实现,每个任务都有自己的 run() 函数。

效果

这种模式的主要好处是其简单,调度程序很难出错。缺点是,该模式对于高紧急事件明显反应较慢,这使得该模式不适合具有高响应性要求的应用程序。该模式的另一个好处是它在所需资源方面非常轻量级,因此非常适合小内存的设备。

使用循环执行模式的一个主要缺点是线程间的交互变得相对复杂。在这种模式下,如果一个任务需要另一个任务的输出数据,那么必须将这些数据存储在全局变量或共享内存中,以确保相关任务在需要时访问这些数据。

另一方面,由于不存在抢占机制,不受控制的阻塞通常不会发生。由阻塞引起的死锁只能由错误引起,比如一个行为不当的任务,该任务永远不会将控制权返回给循环执行体,从而导致整个系统挂起。

在抢占式调度系统中,即使一个任务失败或行为不当,其他任务通常也能够继续运行,除非该任务禁用了任务切换。然而,在循环执行模式中,一个任务的失败可能会导致整个系统停滞不前,直到问题得到解决。因此,在使用循环执行模式时,需要格外注意任务的设计和同步机制的实现,以确保系统的稳定性和可靠性。

实现策略

这种模式的实现几乎简单得不能再简单。在大多数情况下,循环执行器可能只是系统的 main() 函数和相关的全局数据。在其他情况下,循环执行器可能是一个函数,在 main() 函数中调用。

相关模式

由于该模式的响应性明显不是最优的,因此它经常与一些中断服务例程一起用于处理高紧急事件。将 中断模式循环执行模式 一起使用的另一个用途是使用 时间触发的循环执行器 来实现周期计时器响应。

循环执行模式没有解决任务之间的数据共享问题。循环执行模式虽然定义了可用于数据共享的全局数据结构,但为了达到更好的数据共享效果,可以混合使用其他模式(比如后续文章要讲的 任务协调模式)。由于没有抢占,对全局数据的访问不需要保护。

实例

见原书。






读后有收获,资助博主养娃 - 千金难买知识,但可以买好多奶粉 (〃‘▽’〃)
千金难买知识,但可以买好多奶粉

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1481778.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux进程管理:(二)进程调度原语

文章说明: Linux内核版本:5.0 架构:ARM64 参考资料及图片来源:《奔跑吧Linux内核》 Linux 5.0内核源码注释仓库地址: zhangzihengya/LinuxSourceCode_v5.0_study (github.com) 进程调度的概念比较简单&#xff0c…

倒模专用制作耳机壳UV树脂:改性丙烯酸树脂

倒模专用制作耳机壳的UV树脂是经过改性的丙烯酸树脂,具有高透明度、高粘度、快速固化的特点。这种树脂可以通过紫外线光固化,快速形成坚硬的表面,并且具有较高的硬度和耐磨性,因此非常适合用于制作耳机壳。 此外,改性丙…

面试经典 150 题 ---- 轮转数组

面试经典 150 题 ---- 轮转数组 轮转数组方法一:使用额外的数组方法二:数组翻转 轮转数组 方法一:使用额外的数组 我们可以使用额外的数组来将每个元素放至正确的位置。用 n 表示数组的长度,我们遍历原数组,将原数组…

Java SE:多线程(Thread)

1. 线程两个基本概念 并发:即线程交替运行多个指令并行:即多个线程同时运行指令 并发并行不矛盾,两者可同时发生,即多个线程交替运行指令 2. 多线程3种实现方式 2.1 直接创建线程对象 /*** 方式1:* 1. 创建thread类的…

MySQL表分区技术介绍

目录 1. 分区概述 1.1 表分区 1.2 表分区与分表的区别 1.3 表分区的好处 1.4 分区表的限制因素 2. 如何判断当前MySQL是否支持分区? 3. 分区类型详解 3.1 MySQL支持分区类型 3.2 RANGE分区 3.2.1 根据数值范围分区 3.2.2 根据TIMESTAMP范围分区 3.2.3 根…

鸿蒙Harmony应用开发—ArkTS声明式开发(点击事件)

组件被点击时触发的事件。 说明: 从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 onClick onClick(event: (event: ClickEvent) > void) 点击动作触发该回调。 卡片能力: 从API version 9开始…

Python列表的合并、重复、判断与切片操作你学会了吗

1.合并列表 通过 实现 list1 ["佛跳墙", "肠粉", "刀削面", "烤鸭"]list2 [32, 4, 5, 7.43, True]list3 list1 list2print(list3) # [佛跳墙, 肠粉, 刀削面, 烤鸭, 32, 4, 5, 7.43, True] 2.重复输出列表中的元素 通过 * 实…

webstorm 创建运行纯Typescript项目

创建一个空项目,在项目根目录创建一个tsconfig.json文件自动配置: 打开终端输入tsc --init,即可自动生成tsconfig.json文件手动配置: 在项目根目录下新建一个tsconfig.json文件,并配置如下内容 具体配置可以直接使用下面的配置&am…

动态规划(算法竞赛、蓝桥杯)--单调队列滑动窗口与连续子序列的最大和

1、B站视频链接&#xff1a;E11【模板】单调队列 滑动窗口最值_哔哩哔哩_bilibili 题目链接&#xff1a;滑动窗口 /【模板】单调队列 - 洛谷 #include <bits/stdc.h> using namespace std; const int N1000010; int a[N],q[N];//q存的是元素的下标 int main(){int n,k;…

【HTML】HTML基础4(超链接标签)

目录 超链接通用标签 链接分类及其使用 1.外部链接 ​编辑 2.内部链接 3.空链接 4.下载链接 超链接通用标签 <a href"跳转目标" target"目标窗口的弹出方式">文本或者图像</a> 用到的是&#xff1a;<a></a>双标签 其中 1. he…

(2024,LoRA-the-Explorer,并行 LoRA,合并延迟)使用并行 LoRA 从头开始训练神经网络

Training Neural Networks from Scratch with Parallel Low-Rank Adapters 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0. 摘要 2. 基础 3. 方法 3.1. 动机&#xff1a;多头合并…

C++ STL标准程序库开发指南学习笔记

一、类模板简介&#xff1a; 在现今的C标准模板库中&#xff0c;几乎所有的东西都被设计为template形式&#xff0c;不支持模板&#xff0c;就无法使用标准程序库。模板库可以认为是针对一个或多个尚未明确的类型而编写一套函数或类型。模板是C的一个新特性。通过使用模板&…

如何搭建自己的图床

前言 简单来说&#xff0c;图床是一种在线服务&#xff0c;允许用户上传、存储和分享图片。当把图片上传到该服务器上后&#xff0c;便能在互联网上通过链接来使用该图片&#xff0c;尤其是在不允许直接上传图片文件的平台上&#xff0c;也有些平台不允许上传其他平台的图片文…

基于C#开发OPC DA客户端——搭建KEPServerEX服务

简介 OPC DA (OLE for Process Control Data Access) 是一种工业自动化领域中的通信协议标准&#xff0c;它定义了应用程序如何访问由OPC服务器提供的过程控制数据。OPC DA标准允许软件应用程序&#xff08;客户端&#xff09;从OPC服务器读取实时数据或向服务器写入数据&…

Linux时间同步(PPS、PTP、chrony)分析笔记

1 PPS(pulse per second) 1.1 简介 LinuxPPS provides a programming interface (API) to define in the system several PPS sources. PPS means "pulse per second" and a PPS source is just a device which provides a high precision signal each second so t…

C++ //练习 10.16 使用lambda编写你自己版本的biggies。

C Primer&#xff08;第5版&#xff09; 练习 10.16 练习 10.16 使用lambda编写你自己版本的biggies。 环境&#xff1a;Linux Ubuntu&#xff08;云服务器&#xff09; 工具&#xff1a;vim 代码块 /*******************************************************************…

14:00面试,14:07就出来了,问的问题过于变态了。。。

我从一家小公司转投到另一家公司&#xff0c;期待着新的工作环境和机会。然而&#xff0c;新公司的加班文化让我有些始料未及。虽然薪资相对较高&#xff0c;但长时间的工作和缺乏休息使我身心俱疲。 就在我逐渐适应这种高强度的工作节奏时&#xff0c;公司突然宣布了一则令人…

Typora快捷键设置详细教程(内附每个步骤详细截图)

&#x1f60e; 作者介绍&#xff1a;我是程序员洲洲&#xff0c;一个热爱写作的非著名程序员。CSDN全栈优质领域创作者、华为云博客社区云享专家、阿里云博客社区专家博主、前后端开发、人工智能研究生。公粽号&#xff1a;程序员洲洲。 &#x1f388; 本文专栏&#xff1a;本文…

SpringBoot整合MySQL和Druid

✅作者简介:大家好,我是Leo,热爱Java后端开发者,一个想要与大家共同进步的男人😉😉 🍎个人主页:Leo的博客 💞当前专栏: 循序渐进学SpringBoot ✨特色专栏: MySQL学习 🥭本文内容:SpringBoot整合MySQL和Druid 📚个人知识库: Leo知识库,欢迎大家访问 目录 …

HarmonyOS—开发云数据库

您可以在云侧工程下开发云数据库资源&#xff0c;包括创建对象类型、在对象类型中添加数据条目、部署云数据库。 创建对象类型 对象类型&#xff08;即ObjectType&#xff09;用于定义存储对象的集合&#xff0c;不同的对象类型对应的不同数据结构。每创建一个对象类型&#…