(学习日记)2024.03.11:UCOSIII第十三节:使用优先级的流程 (持续更新)

写在前面:
由于时间的不足与学习的碎片化,写博客变得有些奢侈。
但是对于记录学习(忘了以后能快速复习)的渴望一天天变得强烈。
既然如此
不如以天为单位,以时间为顺序,仅仅将博客当做一个知识学习的目录,记录笔者认为最通俗、最有帮助的资料,并尽量总结几句话指明本质,以便于日后搜索起来更加容易。


标题的结构如下:“类型”:“知识点”——“简短的解释”
部分内容由于保密协议无法上传。


点击此处进入学习日记的总目录

2024.03.11

  • 二十七、UCOSIII:使用优先级的流程
    • 1、定义函数
    • 2、创建任务,并设置优先级
    • 3、把任务插入优先级列表
    • 4、把任务插入就绪列表
    • 5、获得当前最高优先级
    • 6、调用最高优先级任务

二十七、UCOSIII:使用优先级的流程

1、定义函数

假设我们要定义一个任务Task1,在app.c中编写代码

void Task1( void *p_arg )
{for ( ;; ) {flag1 = 1;OSTimeDly(2);flag1 = 0;OSTimeDly(2);}
}

2、创建任务,并设置优先级

在程序运行之前,使用OSTaskCreate()函数创建任务 并 设置优先级prio

/* 创建任务 */OSTaskCreate( (OS_TCB*)&Task1TCB,		//在app.c中定义的OS_TCB类型的全局变量(OS_TASK_PTR )Task1,		//任务函数名,类型为OS_TASK_PTR,原型声明在os.h中(void *)0,					//任务形参,用于传递任务参数(OS_PRIO)1,					//优先级(CPU_STK*)&Task1Stk[0],		//指向任务栈的起始地址(CPU_STK_SIZE)  TASK1_STK_SIZE,		//任务栈的大小(OS_ERR *)&err );		//存错误码

OSTaskCreate()声明如下:

void OSTaskCreate (OS_TCB        *p_tcb,OS_TASK_PTR   p_task,void          *p_arg,OS_PRIO       prio,CPU_STK       *p_stk_base,CPU_STK_SIZE  stk_size,OS_ERR        *p_err)

3、把任务插入优先级列表

利用OS_PrioInsert()函数设置优先级表OSPrioTbl中相应的位,代表这个任务已经开始排号

void  OS_PrioInsert (OS_PRIO  prio)

OSPrioTbl优先级表如下:
在这里插入图片描述

4、把任务插入就绪列表

就绪列表不是准备运行的列表,可以理解为一个任务的暂存地。
就绪列表OSRdyList[]的大小由优先级列表确定(其实优先级表 和 就绪列表 成员数量都是由同一个宏OS_CFG_PRIO_MAX来定义的),支持多少个优先级, OSRdyList[]就有多少个成员。

使用OS_RdyListInsert函数把任务插入到就绪列表,优先级为几,就插到下标为几的 就绪列表成员里。

void  OS_RdyListInsert (OS_TCB  *p_tcb)

每个就绪列表成员都包含三个变量,分别是头任务指针HeadPtr,尾任务指针TailPtr,任务总数NbrEntries
在这里插入图片描述
所以一个优先级可以有很多任务,但目前的代码是按照每个优先级只有一个任务来处理的

5、获得当前最高优先级

利用OS_PrioGetHighest()函数从优先级表OSPrioTbl中查找最高的优先级,并返回该优先级prio

OS_PRIO  OS_PrioGetHighest (void)

在这里插入图片描述

寻找办法为

  1. 优先级表OSPrioTbl的头指针依次递增判断是否为 0(准确来说是32个0),再对第一个不为0OSPrioTbl成员使用CPU_CntLeadZeros函数。
    在这个过程中,每跳过一个OSPrioTbl成员,都要给优先级prio+32 (因为我们设置一个OSPrioTbl成员为32位)
  2. CPU_CntLeadZeros函数作用为把32位拆成4个8位,从高8位到低8位找到第一个不为0的8位,计算其前导0数量,再加上高位8位数量(比如第三个8位不为0,那就第三个8位的前导0数量 + 16),把最后的值加给优先级prio
  3. 返回prio,这个数就是目前最高的优先级

6、调用最高优先级任务

通过优先级调用就绪列表的任务,按顺序调用
如果任务陷入阻塞状态,那么就在优先级表中把对应优先级设为0.

这里只需将任务在优先级表中对应的位清除即可,暂时不需要把任务TCB从OSRdyList[]中移除, 因为接下来OSTimeTick()函数还是通过扫描OSRdyList[]来判断任务的延时时间是否到期。
当我们加入了时基列表之后, 当任务调用OSTimeDly()函数进行延时,就可以把任务的TCB从就绪列表删除,然后把任务TCB插入时基列表, OSTimeTick()函数判断任务的延时是否到期只需通过扫描时基列表即可,时基列表在下一个章节实现。
所以这里暂时不能把TCB从就绪列表中删除,只是将任务优先级在优先级表中对应的位清除来达到任务不处于就绪态的目的。

阻塞状态结束,就将优先级再改回1
这部分代码由于涉及系统时钟,所以放在SysTick中断服务函数中,由系统调用
在这里插入图片描述

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

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

相关文章

vulntarget-k - 内网渗透

标签 xxl-job rce Spring-Cloud-CVE-2022-22947 nacos auth bypass iox 靶机难度比较简单,都是用用 exp 就好了 拓扑图 网卡设置 首先需要使用虚拟网络编辑器,增加 VMnet1、VMnet2、VMnet3 对三张网卡设置子网 IP VMnet1 192.168.100.0 VMnet2 1…

EM算法详解

EM(Expectation-Maximum)算法也称期望最大化算法,曾入选“数据挖掘十大算法”中,可见EM算法在机器学习、数据挖掘中的影响力。EM算法是最常见的隐变量估计方法,在机器学习中有极为广泛的用途,例如常被用来学习高斯混合模型(Gaussian mixture model,简称GMM)的参数;隐…

SIP-7043 20W SIP网络有源吸顶喇叭

SIP-7043 20W SIP网络有源吸顶喇叭 一、描述 18123651365微信 声卡喊话IP喇叭,IP网络吸顶天花喇叭 SIP-7043VP是我司的一款SIP网络有源吸顶喇叭,具有10/100M以太网接口,内置有一个高品质扬声器,将网络音源通过自带的功放和喇叭…

jpg格式图片怎么生成二维码?扫码看图在线制作方法

多张jpg格式的图片如何做成二维码展示?jpg是现在最常用的一种图片格式,不管是拍摄的照片、设计图片或是其他类型的图片基本上都是这种格式。那么如何将jpg格式的图片放到二维码中展示呢?通过下面的文章内容来分享一下图片制作二维码在线的技巧…

scrcpy远程投屏控制Android

下载 下载后解压压缩包scrcpy-win64-v2.4.zip scrcpy连接手机 1. 有线连接 - 手机开启开发者选项,并开启USB调试,连接电脑,华为手机示例解压scrcpy,在scrcpy目录下打开终端,(或添加scrcpy路径为环境变…

前端面试题 ===> 【HTML】

HTML面试题总结 1. 对 HTML 语义化的理解 去掉或者丢失样式的时候能够让页面呈现出清晰的结构;代码结构清晰,方便团队的管理和维护,并且语义化更具有可读性,减少差异化;提升用户体验; 例如:ti…

【数组】41. 缺失的第一个正数【困难】

缺失的第一个正数 给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数。请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。 示例 1 输入:nums [1,2,0]输出:3 示例 2 输入:nums [3,4,-1,…

同态滤波算法详解

同态滤波是一种用于增强图像的方法,特别适用于去除图像中的照明不均和阴影。该算法基于照射反射模型,将图像分解为两个分量:照射分量(illumination component)和反射分量(reflection component)…

精品基于Uniapp+ssm停车场预约缴费微信小程序的设计与实现

《[含文档PPT源码等]精品微信小程序基于Uniappssm停车场微信小程序的设计与实现》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程! 软件开发环境及开发工具: 开发语言:Java 后台框架:ssm 安卓框架&…

Python打印输出Linux中最常用的linux命令之示例

一、Linux中的~/.bash_history文件说明: 该文件保存了linux系统中运行过的命令的历史。使用该文件来获取命令的列表,并统计命令的执行次数。统计时,只统计命令的名称,以不同参数调用相同的命令也视为同一命令。 二、示例代码&am…

csp模拟题(201604-2,俄罗斯方块模拟下坠)

题目 问题描述 俄罗斯方块是俄罗斯人阿列克谢帕基特诺夫发明的一款休闲游戏。   游戏在一个15行10列的方格图上进行,方格图上的每一个格子可能已经放置了方块,或者没有放置方块。每一轮,都会有一个新的由4个小方块组成的板块从方格图的上方…

一文掌握Python控制语句操作及实例详解

在 Python 中,控制语句是用于流程控制的重要工具,可以帮助我们根据不同的条件执行不同的代码块。本文将带你快速掌握 Python 中的控制语句操作,并通过实际例子让你更好地理解。 1. 条件控制语句:if-elif-else Python中的条件判断主要依赖于if,elif(else if)和else语句…

应急响应实战笔记03权限维持篇(6)

0x00 前言 在渗透测试中,有三个非常经典的渗透测试框架----Metasploit、Empire、Cobalt Strike。 那么,通过漏洞获取到目标主机权限后,如何利用框架获得持久性权限呢? 0x01 MSF权限维持 使用MSF维持权限的前提是先获得一个met…

蓝桥集训之正则问题

蓝桥集训之正则问题 核心思想&#xff1a;递归 归结到一棵树 向上返回x数量 #include<iostream>#include<cstring>using namespace std;int k;string str;int dfs(){int res0; //记录x数量while(k<str.size()){if(str[k] (){k ; //跳过左括号res dfs();k …

【C#】【SAP2000】OAPI文档案例详解

创建一个简单的结构模型,运行分析,提取结果,并将结果与手算值进行比较。 以下是详细的代码解析: 开头部分是一些using语句,引用了必要的命名空间,特别是SAP2000v1, 它包含了SAP2000 API的类和方法。 在Main方法中,首先定义了一些变量,用于控制是启动一个新的SAP2000实例还是附…

【JVM】Java虚拟机调优 配置启动参数

一、配置方式 options - JVM启动参数。 配置多个参数的时候&#xff0c;参数之间使用空格分隔 参数命名&#xff1a; 常见为 -参数名 参数赋值&#xff1a; 常见为 -参数名参数值 | -参数名:参数值 二、内存参数 -Xms:初始堆大小&#xff0c;JVM启动的时候&#xff0c;给定…

C++:vector类

vector的介绍及使用 1. vector 是表示可变大小数组的序列容器。 2. 就像数组一样&#xff0c; vector 也采用的连续存储空间来存储元素。也就是意味着可以采用下标对 vector 的元素进行访问&#xff0c;和数组一样高效。但是又不像数组&#xff0c;它的大小是可以动态改变的…

虾皮shopee根据ID取商品详情 API

公共参数 名称类型必须描述keyString是免费申请调用key&#xff08;必须以GET方式拼接在URL中&#xff09;secretString是调用密钥api_nameString是API接口名称&#xff08;包括在请求地址中&#xff09;[item_search,item_get,item_search_shop等]cacheString否[yes,no]默认y…

pxe安装mini centos系统

一、准备工作 1、关闭防火墙和selinux systemctl stop firewalld && systemctl disable firewalldsetenforce 02、配置静态ip 需要在dhcp里面填写tftp配置&#xff0c;所以需要固定ip 二、dhcp安装配置 作用&#xff1a;给客户端提供ip地址&#xff0c;并告诉客户…

html5cssjs代码 017样式示例

html5&css&js代码 017样式示例 一、代码二、解释 这段HTML代码定义了一个网页的基本结构&#xff0c;包括头部、主体和尾部。在头部中&#xff0c;设置了网页标题、字符编码和样式。主体部分包含一个标题和一个表格&#xff0c;表格内分为两个单元格&#xff0c;左侧为…