FreeRTOS学习笔记—④RTOS通信管理篇/同步互斥与通信(正在更新中)

2024-09-07 04:20

本文主要是介绍FreeRTOS学习笔记—④RTOS通信管理篇/同步互斥与通信(正在更新中),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

二、RTOS的核心功能

  RTOS的核心功能块主要分为任务管理、内核管理、时间管理以及通信管理4部分,框架图如下所示:
  (1)任务管理:负责管理和调度任务的执行,确保系统中的任务能够按照预期运行。
  (2)内核管理:负责系统核心功能的管理,包括内存、中断、异常处理和系统启动等。
  (3)时间管理:负责所有与时间相关的操作,包括系统时钟、定时器、任务延迟和周期性任务的执行。
  (4)通信管理:提供任务之间的通信机制,确保任务能够有效地协作和共享资源。
在这里插入图片描述

2.3 通信管理

  RTOS的通信管理部分主要由同步互斥与通信构成。其中同步与互斥主要用于解决任务间的时间协调和共享资源保护的问题,而通信机制负责在任务间传递数据。因此两者通常结合使用来确保多任务在并发环境下的正确性和高效性。
  (1)同步:指的是多任务在执行的时候,某些步骤需要按照一定顺序进行,通过这种同步机制来确保多个任务之间能够协同工作,避免竞争条件。eg.比如说任务A需要等待任务B完成某个操作后再执行。
  (2)互斥:指的是用于防止多个任务同时访问一个共享资源,相比同步来说好理解些。
  (3)通信:指的是任务之间交换数据或信息的机制。通常用于多个任务间传递消息或数据来实现更复杂的任务协调。
  其中典型的同步与互斥机制包括信号量、互斥量(mutex)、事件组等;通信机制通常包括队列、任务通知等。在某些情况下,事件组也可以承担简单的任务间通信功能。这些其实也能说是同步与互斥的内核方法。
  信号量、互斥量(mutex)、事件组、队列、任务通知这些内核方法的操作都是:获取/释放、阻塞/唤醒、超时等,如下:
   ① A获取资源,用完后释放资源;
   ② A获取不到资源会进入阻塞,当B释放资源后把A唤醒让A来获取资源;
   ③ A获取不到资源会进入阻塞状态,可以定个闹钟来规定任务A等待的最大等待时长Tmax。如果A等待的时间超过了Tmax(即超时),那么会超时返回一个超时错误或继续执行其他任务。另一种情况则是在Tmax内B把资源释放了,即使A未超时也会被立刻唤醒,从阻塞状态恢复执行。
   下图为这几种方法的对比以及示意图,摘自韦东山老师的FreeRTOS手册:
在这里插入图片描述
在这里插入图片描述

2.3.1 队列

这篇关于FreeRTOS学习笔记—④RTOS通信管理篇/同步互斥与通信(正在更新中)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144043

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl