FreeRTOS系列第17篇---FreeRTOS队列
本文介绍队列的基本知识,具体源代码分析见《FreeRTOS高级篇5---FreeRTOS队列分析》
1.FreeRTOS队列
队列是基本的任务间通讯方式。能够在任务与任务间、中断和任务间传送信息。大多数情况下,队列用于具有线程保护的FIFO(先进先出)缓冲区:新数据放在队列的后面。当然。数据也能够放在队列的前面,在下一篇讲队列API函数时,会涉及到数据的存放位置。
图1-1:读写队列
图1-1所看到的的队列中。最多能保存5个项目,而且假设队列永远不会满。任务A使用API函数xQueueSendToBack()向队列发送数据。每次发送一个数据。新入队的数据置于上一次入队数据的后面。
任务B使用API函数xQueueReceive()将数据从队列取出,先入队的数据先出队。
2.使用模型:最简单、最灵活
通常情况下,鱼和熊掌是不可兼得的。但FreeRTOS的队列用户模型管理却兼顾简单和灵活。发送到队列的消息是通过拷贝实现的,这意味着队列存储的数据是原数据,而不是原数据的引用。
FreeRTOS队列具有下面特性:
- C变量(整形、简单结构体等等)中的简单信息能够直接传送到队列。这样就不须要为信息分配缓存也不须要再进行什么拷贝工作。
相同的。信息能够直接从队列读取到C变量中。用直接拷贝的方法入队,能够同意任务马上覆写已经入队的变量或者缓存,实际上队列中已经保存了这些变量或缓冲区携带的信息。由于变量中的数据内容是以拷贝的方式入队的,所以变量自身是同意反复使用的。发送信息的任务和接收信息的任务并不须要就哪个任务拥有信息、哪个任务释放信息(当信息不再使用时)而达成一致。
- 队列是通过拷贝传递数据的,但这并最好还是碍队列通过引用来传递数据。
当信息的大小到达一个临界点后,逐字节拷贝整个信息是不实际的,能够定义一个指针队列,仅仅拷贝指向消息的指针来取代整个信息拷贝。
FreeRTOS+UDP IP栈例程正是使用这样的方法向FreeRTOS协议栈传递大量网络数据的。
- 队列内存区域分配由内核完毕。
- 变长消息能够通过定义保存一个结构体变量的队列实现。结构体一个成员指向要入队的缓存。还有一个成员保存缓存数据的大小。
- 单个队列能够接收不同类型信息,而且信息能够来自不同的位置。
通过定义保存一个结构体变量的队列来实现。结构体的一个成员保存信息类型。还有一个成员保存信息数据(或者指向信息数据的指针)。数据怎样解读取决于信息类型。
管理FreeRTOS+UDP IP栈的任务正是使用单个队列接收ARP定时器时间通知、以太网硬件传送来的数据包、从应用层传送来的数据包、网络关闭事件等等。
- 天生适用于那些内存保护(MPU)场合。一个具有内存区域保护的任务能够向还有一个具有内存区域保护的任务传递数据,由于调用队列发送函数会引起RTOS提升微控制器特权级别。仅仅有RTOS(具有全部特权)才干够訪问队列存储区域。
- 在中断函数中使用独立的API。将RTOS任务API和中断服务例程API分来实现意味着能够避免执行时的上下文调用检查开销,还意味着在大多数情况下。与其他RTOS产品相比。用户创建中断服务例程会更简单。
- API函数非常easy。
3.队列堵塞
API函数同意指定堵塞时间。
每当任务企图从一个空的队列读取数据时,任务会进入堵塞状态(这样任务不会消耗不论什么CPU时间而且还有一个任务能够执行)直到队列中出现有效数据或者堵塞时间到期。
每当任务企图向一个满的队列写数据时,任务会进入堵塞状态,直到队列中出现有效空间或者堵塞时间到期。
假设多个任务堵塞在一个队列上。那么最高优先级别的任务会第一个解除堵塞。
注:中断程序中绝不能够使用不带“FromISR”结尾的API函数!
总结一下队列的基本使用方法:
- 定义一个队列句柄变量,用于保存创建的队列:xQueueHandle xQueue1;
- 使用API函数xQueueCreate()创建一个队列。
- 假设希望使用先进先出队列,使用API函数xQueueSend()或xQueueSendToBack()向队列投递队列项。假设希望使用后进先出队列。使用API函数xQueueSendToFront()向队列投递队列项。假设在中断服务程序中。切记使用它们的带中断保护版本号。
- 使用API函数xQueueReceive()从队列读取队列项,假设在中断服务程序中,切记使用它们的带中断保护版本号。
FreeRTOS系列第17篇---FreeRTOS队列的更多相关文章
- FreeRTOS系列第2篇---FreeRTOS入门指南【转】
转自:http://blog.csdn.net/zhzht19861011/article/details/49819309 版权声明:本文为博主原创文章,未经博主允许不得转载.联系邮箱:zhzhch ...
- FreeRTOS系列第14篇---FreeRTOS任务通知
注:本文介绍任务通知的基础知识,具体源代码分析见<FreeRTOS高级篇8---FreeRTOS任务通知分析> 每一个RTOS任务都有一个32位的通知值,任务创建时,这个值被初始化为0.R ...
- FreeRTOS系列第20篇---FreeRTOS信号量API函数
FreeRTOS的信号量包括二进制信号量.计数信号量.相互排斥信号量(以后简称相互排斥量)和递归相互排斥信号量(以后简称递归相互排斥量).我们能够把相互排斥量和递归相互排斥量看成特殊的信号量. 信号量 ...
- FreeRTOS系列第13篇---FreeRTOS内核控制
内核控制的一些功能须要移植层提供,为了方便移植.这些API函数用宏来实现,比方上下文切换.进入和退出临界区.禁止和使能可屏蔽中断.内核控制函数还包含启动和停止调度器.挂起和恢复调度器以及用于低功耗模式 ...
- spring 5.x 系列第17篇 —— 整合websocket (xml配置方式)
源码Gitub地址:https://github.com/heibaiying/spring-samples-for-all 一.说明 1.1 项目结构说明 项目模拟一个简单的群聊功能,为区分不同的聊 ...
- java高并发系列 - 第17天:JUC中的循环栅栏CyclicBarrier常见的6种使用场景及代码示例
这是java高并发系列第17篇. 本文主要内容: 介绍CyclicBarrier 6个示例介绍CyclicBarrier的使用 对比CyclicBarrier和CountDownLatch Cycli ...
- 【Flutter 实战】17篇动画系列文章带你走进自定义动画
老孟导读:Flutter 动画系列文章分为三部分:基础原理和核心概念.系统动画组件.8篇自定义动画案例,共17篇. 动画核心概念 在开发App的过程中,自定义动画必不可少,Flutter 中想要自定义 ...
- Mysql高手系列 - 第9篇:详解分组查询,mysql分组有大坑!
这是Mysql系列第9篇. 环境:mysql5.7.25,cmd命令中进行演示. 本篇内容 分组查询语法 聚合函数 单字段分组 多字段分组 分组前筛选数据 分组后筛选数据 where和having的区 ...
- java高并发系列 - 第26篇:学会使用JUC中常见的集合,常看看!
这是java高并发系列第26篇文章. 环境:jdk1.8. 本文内容 了解JUC常见集合,学会使用 ConcurrentHashMap ConcurrentSkipListMap Concurrent ...
随机推荐
- 新手IOS tweak越狱app开发记录
需要改变原先程序功能流程的话,是要用到Logos Tweak 开发.另外,.在苹果商城下载到的app,不能直接拿来分析.需要先做一定的前期准备.网上有很多相关的写第一个越狱插件的文章,这里就不在赘言了 ...
- 《C++ Primer》 第四版 第7章 函数
<C++ Primer> 第四版 第7章 函数 思维导图笔记 超级具体.很具体,图片版,有利于复习查看 http://download.csdn.net/detail/onlyshi/94 ...
- 【构建Android缓存模块】(一)吐槽与原理分析
http://my.oschina.net/ryanhoo/blog/93285 摘要:在我翻译的Google官方系列教程中,Bitmap系列由浅入深地介绍了如何正确的解码Bitmap,异步线程操作以 ...
- Can rename table but can not truncate table
一个表无法truncate可是能够rename,这个乍听起来认为好奇怪,以下模拟该过程. 3个session: session1运行truncate和rename操作. session2运行lock表 ...
- 登录首页时报错:java.lang.IllegalArgumentException (不合法的参数异常)
处理一个老项目,DOWN下项目并配好之后,启动没问题,但是登陆之后首页显示如下: 控制台报错如下: 严重: Servlet.service() for servlet jsp threw except ...
- 事件总线框架---Otto
我们假设这样一种业务场景,现在在做一款及时聊天应用,我们在聊天页面进行收发信息,同时也要实时更新前一页面的聊天记录,这时我们该如何去实现?说说我以前的实现策略,我使用的是广播接收器BroadCastR ...
- R语言的if-else
语法问题,类似于for函数使用时必须把"{"放在当前行,而不可以独占一行.R的特色. 具体你的这个问题可以尝试 x <- 5 if (x>0){ print(" ...
- join和countDownLatch原理及区别详解
先上结论 原理 join 原理:在当前线程中调用另一个线程线程 thread 的 join() 方法时,会调用该 thread 的 wait() 方法,直到这个 thread 执行完毕(JVM在 ru ...
- SSDB(网络LevelDB)-- 实际遇到的问题
简介 SSDB -- 支持网络的LevelDB 站点:https://github.com/ideawu/ssdb 我实际使用了SSDB支持网络+持久化特性,完成了一个集群 1.句柄数 ulimit ...
- LinkedList的一种错误使用方法
近期在做图像处理的时候.发现某一段代码很的慢.慢得让人无法接受.基本的代码是顺序訪问一个LinkedList的元素,效果是随着index的变大,速度越来越慢,list的元素个数在百万以上.找到原因,分 ...