STM32与Freertos入门(六)队列

1、队列介绍

队列是FreeRTOS提供的一种重要的通信机制,用于在任务之间传递数据。

FreeRTOS队列是一种先进先出(FIFO)的数据结构,用于在任务之间传递消息或数据项。它允许一个任务将数据项发送到队列,而另一个任务则可以从队列中接收这些数据项。

以下是FreeRTOS队列的一些重要特点和用法:

  1. 队列创建:可以使用FreeRTOS提供的API函数创建队列。在创建队列时,需要指定队列的最大长度和每个数据项的大小。

  2. 发送数据:任务可以使用xQueueSend()函数将数据项发送到队列中。如果队列已满,发送操作将被阻塞,直到有空间可用。

  3. 接收数据:任务可以使用xQueueReceive()函数从队列中接收数据项。如果队列为空,接收操作将被阻塞,直到有数据可用。

  4. 队列优先级:FreeRTOS队列还支持优先级功能。可以为队列设置优先级,使得在同时有多个任务等待发送或接收数据时,根据优先级决定哪个任务先进行操作。

  5. 队列长度:通过查询队列的长度,可以了解当前队列中待处理的数据项数量。这对于任务调度和资源管理非常有用。

使用FreeRTOS队列时,需要注意以下几点:

  • 需要合理设置队列的长度,确保不会超过任务处理能力。
  • 当队列满或空时,任务可能会被阻塞,因此要小心处理该种情况以避免死锁。
  • 在多任务环境下,要注意同步和竞争条件,以确保数据的正确性和一致性。

总的来说,FreeRTOS队列提供了一种方便和高效的任务间通信机制,可以在嵌入式系统中实现数据传递和同步。它是FreeRTOS强大功能的一部分,帮助开发人员编写可靠的实时应用程序。

2、队列测试

2.1 任务创建

2.2 队列建立

3、队列API

 3.1 创建队列

QueueHandle_t xQueueCreate( UBaseType_t uxQueueLength, UBaseType_t uxItemSize );
  • 参数:
    • uxQueueLength:队列可同时容纳的最大项目数 。
    • uxItemSize:存储队列中的每个数据项所需的大小(以字节为单位)。
  • 返回值: 
    • 如果队列创建成功,则返回所创建队列的句柄 。 如果创建队列所需的内存无法分配,则返回 NULL。

 3.2 写队列

BaseType_t xQueueSend(QueueHandle_t xQueue,const void * pvItemToQueue,TickType_t xTicksToWait);
  • 参数:
    • xQueue:队列的句柄,数据项将发送到此队列。
    • pvItemToQueue:待写入数据
    • xTicksToWait:阻塞超时时间
  • 返回值:
    • 如果成功写入数据,返回 pdTRUE,否则返回 errQUEUE_FULL。

  3.3读队列

BaseType_t xQueueReceive(QueueHandle_t xQueue,void *pvBuffer,TickType_t xTicksToWait);
  • 参数:
    • xQueue:待读取的队列
    • pvItemToQueue:数据读取缓冲区
    • xTicksToWait:阻塞超时时间
  • 返回值:
    • 成功返回 pdTRUE,否则返回 pdFALSE。

4、KEIL 5代码设计

4.1 写队列函数

void StartTask_send(void const * argument)
{/* USER CODE BEGIN StartTask_send */uint16_t buf = 100;BaseType_t status;/* Infinite loop */for(;;){if(key==0){ osDelay(20);if(key==0){printf("key按下\r\n");status=xQueueSend(myQueueHandle,&buf,0);if(status == pdTRUE){printf("写入队列成功,写入值%d\r\n",buf);}else{printf("写入失败\r\n");}}	while(key==0);}osDelay(10);}/* USER CODE END StartTask_send */
}

4.2 读队列函数

void StartTask_receive(void const * argument)
{/* USER CODE BEGIN StartTask_receive */uint16_t buf;BaseType_t status;/* Infinite loop */for(;;){if(key2==0){ osDelay(20);if(key2==0){printf("key2按下\r\n");status=xQueueReceive(myQueueHandle,&buf,0);if(status == pdTRUE){printf("读取队列成功,读出值%d\r\n",buf);}else{printf("读取失败\r\n");}}	while(key2==0);}osDelay(10);}/* USER CODE END StartTask_receive */
}

freertos.c代码如下:

/* USER CODE BEGIN Header */
/********************************************************************************* File Name          : freertos.c* Description        : Code for freertos applications******************************************************************************* @attention** Copyright (c) 2023 STMicroelectronics.* All rights reserved.** This software is licensed under terms that can be found in the LICENSE file* in the root directory of this software component.* If no LICENSE file comes with this software, it is provided AS-IS.********************************************************************************/
/* USER CODE END Header *//* Includes ------------------------------------------------------------------*/
#include "FreeRTOS.h"
#include "task.h"
#include "main.h"
#include "cmsis_os.h"/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes *//* USER CODE END Includes *//* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD *//* USER CODE END PTD *//* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD *//* USER CODE END PD *//* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM *//* USER CODE END PM *//* Private variables ---------------------------------------------------------*/
/* USER CODE BEGIN Variables *//* USER CODE END Variables */
osThreadId Task_sendHandle;
osThreadId Task_receiveHandle;
osMessageQId myQueueHandle;/* Private function prototypes -----------------------------------------------*/
/* USER CODE BEGIN FunctionPrototypes *//* USER CODE END FunctionPrototypes */void StartTask_send(void const * argument);
void StartTask_receive(void const * argument);void MX_FREERTOS_Init(void); /* (MISRA C 2004 rule 8.1) *//* GetIdleTaskMemory prototype (linked to static allocation support) */
void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize );/* USER CODE BEGIN GET_IDLE_TASK_MEMORY */
static StaticTask_t xIdleTaskTCBBuffer;
static StackType_t xIdleStack[configMINIMAL_STACK_SIZE];void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize )
{*ppxIdleTaskTCBBuffer = &xIdleTaskTCBBuffer;*ppxIdleTaskStackBuffer = &xIdleStack[0];*pulIdleTaskStackSize = configMINIMAL_STACK_SIZE;/* place for user code */
}
/* USER CODE END GET_IDLE_TASK_MEMORY *//*** @brief  FreeRTOS initialization* @param  None* @retval None*/
void MX_FREERTOS_Init(void) {/* USER CODE BEGIN Init *//* USER CODE END Init *//* USER CODE BEGIN RTOS_MUTEX *//* add mutexes, ... *//* USER CODE END RTOS_MUTEX *//* USER CODE BEGIN RTOS_SEMAPHORES *//* add semaphores, ... *//* USER CODE END RTOS_SEMAPHORES *//* USER CODE BEGIN RTOS_TIMERS *//* start timers, add new ones, ... *//* USER CODE END RTOS_TIMERS *//* Create the queue(s) *//* definition and creation of myQueue */osMessageQDef(myQueue, 16, uint16_t);myQueueHandle = osMessageCreate(osMessageQ(myQueue), NULL);/* USER CODE BEGIN RTOS_QUEUES *//* add queues, ... *//* USER CODE END RTOS_QUEUES *//* Create the thread(s) *//* definition and creation of Task_send */osThreadDef(Task_send, StartTask_send, osPriorityNormal, 0, 128);Task_sendHandle = osThreadCreate(osThread(Task_send), NULL);/* definition and creation of Task_receive */osThreadDef(Task_receive, StartTask_receive, osPriorityBelowNormal, 0, 128);Task_receiveHandle = osThreadCreate(osThread(Task_receive), NULL);/* USER CODE BEGIN RTOS_THREADS *//* add threads, ... *//* USER CODE END RTOS_THREADS */}/* USER CODE BEGIN Header_StartTask_send */
/*** @brief  Function implementing the Task_send thread.* @param  argument: Not used* @retval None*/
/* USER CODE END Header_StartTask_send */
void StartTask_send(void const * argument)
{/* USER CODE BEGIN StartTask_send */uint16_t buf = 100;BaseType_t status;/* Infinite loop */for(;;){if(key==0){ osDelay(20);if(key==0){printf("key按下\r\n");status=xQueueSend(myQueueHandle,&buf,0);if(status == pdTRUE){printf("写入队列成功,写入值%d\r\n",buf);}else{printf("写入失败\r\n");}}	while(key==0);}osDelay(10);}/* USER CODE END StartTask_send */
}/* USER CODE BEGIN Header_StartTask_receive */
/**
* @brief Function implementing the Task_receive thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_receive */
void StartTask_receive(void const * argument)
{/* USER CODE BEGIN StartTask_receive */uint16_t buf;BaseType_t status;/* Infinite loop */for(;;){if(key2==0){ osDelay(20);if(key2==0){printf("key2按下\r\n");status=xQueueReceive(myQueueHandle,&buf,0);if(status == pdTRUE){printf("读取队列成功,读出值%d\r\n",buf);}else{printf("读取失败\r\n");}}	while(key2==0);}osDelay(10);}/* USER CODE END StartTask_receive */
}
/* Private application code --------------------------------------------------*/
/* USER CODE BEGIN Application *//* USER CODE END Application */

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自己动手写编译器:语法解析的基本原理

在前面系列章节中我们完成了词法解析。词法解析的基本任务就是判断给定字符串是否符合特定规则,如果符合那么就给这个字符串分配一个标签(token)。词法解析完成后接下来的工作就要分配给语法解析,后者的任务就是判断一系列标签的组合是否符合特定规范。 …

爬虫中scrapy模块的概念作用和工作流程

scrapy的概念和流程 学习目标: 了解 scrapy的概念了解 scrapy框架的作用掌握 scrapy框架的运行流程掌握 scrapy中每个模块的作用 1. scrapy的概念 Scrapy是一个Python编写的开源网络爬虫框架。它是一个被设计用于爬取网络数据、提取结构性数据的框架。 Scrapy 使…

面试算法56:二叉搜索树中两个节点的值之和

题目 给定一棵二叉搜索树和一个值k,请判断该二叉搜索树中是否存在值之和等于k的两个节点。假设二叉搜索树中节点的值均唯一。例如,在如图8.12所示的二叉搜索树中,存在值之和等于12的两个节点(节点5和节点7)&#xff0…

乔拓云平台:从小程序到多平台,全面满足需求

随着移动互联网的快速发展,小程序作为一种轻量级的应用程序,逐渐成为了企业和个人进行营销和提供服务的重要工具。然而,对于许多非技术用户来说,自行开发小程序往往面临较高的门槛和成本。为了解决这一问题,乔拓云第三…

数据可视化---饼图、环形图、雷达图

类别内容导航机器学习机器学习算法应用场景与评价指标机器学习算法—分类机器学习算法—回归机器学习算法—聚类机器学习算法—异常检测机器学习算法—时间序列数据可视化数据可视化—折线图数据可视化—箱线图数据可视化—柱状图数据可视化—饼图、环形图、雷达图统计学检验箱…

ViewBinding与DataBinding(视图绑定与数据双向绑定)

前言:心中纵是有所盼 严寒没有减 风很冷 我的手已渐蓝 前言 控件查找对于Android开发来说也是一部血泪史,一直为更有效的方案进行了多种方案的研究和探讨。findViewById() 过于繁琐,强制转换不安全;butterkniife 会存在众多臃肿的…

期货高低板(期货价格飘升,市场掀起高低潮流)

什么是期货高低板? 期货是由交易所统一交易的标准化合约,商品的价格是通过供求关系来决定的。高低板则是期货交易中的常见现象,它表示了在交易过程中,价格波动超过了可设定的最高或最低价,于是交易系统便会出现高板或…

【docker 】Compose 使用介绍

Docker Compose Docker Compose文档 Docker Compose GitHub地址 Docker Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配…

BKP 备份寄存器 RTC 实时时钟-stm32入门

这一章节我们要讲的主要内容是 RTC 实时时钟,对应手册,是第 16 章的位置。 实时时钟这个东西,本质上是一个定时器,但是这个定时器,是专门用来产生年月日时分秒,这种日期和时间信息的。所以学会了 STM32 的…

bootstap table表格, 获取当前点击的table元素在该行是第几个

背景 有这样一个需求, table表格中是统计数据, 要求点击每个单元格可实现导出统计的底层数据 数据都是可点击导出的, 思路 获取行bootstap 有个index参数, 所哟要获取当前行第几列, 要获取当前点击的table元素在其所在行中的位置(即第几个)&#xff…

20、WEB攻防——PHP特性缺陷对比函数CTF考点CMS审计实例

文章目录 一、PHP常用过滤函数:1.1 与1.2 md51.3 intval1.4 strpos1.5 in_array1.6 preg_match1.7 str_replace CTFshow演示三、参考资料 一、PHP常用过滤函数: 1.1 与 :弱类型对比(不考虑数据类型),甚至…

【程序】STM32 读取光栅_编码器_光栅传感器_7针OLED

文章目录 源代码工程编码器基础程序参考资料 源代码工程 源代码工程打开获取: http://dt2.8tupian.net/2/28880a55b6666.pg3这里做了四倍细分,在屏幕上显示 速度、路程、方向。 接线方法: 单片机--------------串口模块 单片机的5V-------…