鸿蒙OpenHarmony【小型系统基础内核(进程管理任务)】子系统开发

任务

基本概念

从系统的角度看,任务Task是竞争系统资源的最小运行单元。任务可以使用或等待CPU、使用内存空间等系统资源,并独立于其它任务运行。

OpenHarmony 内核中使用一个任务表示一个线程。

OpenHarmony 内核中同优先级进程内的任务统一调度、运行。

OpenHarmony 内核中的任务采用抢占式调度机制,同时支持时间片轮转调度和FIFO调度方式。

OpenHarmony 内核的任务一共有32个优先级(0-31),最高优先级为0,最低优先级为31。

当前进程内, 高优先级的任务可抢占低优先级任务,低优先级任务必须在高优先级任务阻塞或结束后才能得到调度。

任务状态说明

  • 初始化(Init):任务正在被创建。

  • 就绪(Ready):任务在就绪列表中,等待CPU调度。

  • 运行(Running):任务正在运行。

  • 阻塞(Blocked):任务被阻塞挂起。Blocked状态包括:pending(因为锁、事件、信号量等阻塞)、suspended(主动pend)、delay(延时阻塞)、pendtime(因为锁、事件、信号量时间等超时等待)。

  • 退出(Exit):任务运行结束,等待父任务回收其控制块资源。

    图1 任务状态迁移示意图

    1

任务状态迁移说明:

  • Init→Ready: 任务创建拿到控制块后为初始化阶段(Init状态),当任务初始化完成将任务插入调度队列,此时任务进入就绪状态。
  • Ready→Running: 任务创建后进入就绪态,发生任务切换时,就绪列表中最高优先级的任务被执行,从而进入运行态,此刻该任务从就绪列表中删除。
  • Running→Blocked: 正在运行的任务发生阻塞(挂起、延时、读信号量等)时,任务状态由运行态变成阻塞态,然后发生任务切换,运行就绪列表中剩余最高优先级任务。
  • Blocked→Ready : 阻塞的任务被恢复后(任务恢复、延时时间超时、读信号量超时或读到信号量等),此时被恢复的任务会被加入就绪列表,从而由阻塞态变成就绪态。
  • Ready→Blocked: 任务也有可能在就绪态时被阻塞(挂起),此时任务状态会由就绪态转变为阻塞态,该任务从就绪列表中删除,不会参与任务调度,直到该任务被恢复。
  • Running→Ready: 有更高优先级任务创建或者恢复后,会发生任务调度,此刻就绪列表中最高优先级任务变为运行态,那么原先运行的任务由运行态变为就绪态,并加入就绪列表中。
  • Running→Exit: 运行中的任务运行结束,任务状态由运行态变为退出态。若为设置了分离属性( 由头文件 los_task.h 中的宏定义 LOS_TASK_STATUS_DETACHED 设置)的任务,运行结束后将直接销毁。

运行机制

OpenHarmony 任务管理模块提供任务创建、任务延时、任务挂起和任务恢复、锁任务调度和解锁任务调度、根据ID查询任务控制块信息功能。

用户创建任务时,系统会将任务栈进行初始化,预置上下文。此外,系统还会将“任务入口函数”地址放在相应位置。这样在任务第一次启动进入运行态时,将会执行任务入口函数。

开发指导

接口说明

表1 任务的创建和删除
接口名接口描述
LOS_TaskCreate创建任务,若所创建任务的优先级比当前的运行的任务优先级高且任务调度没有锁定, 则该任务将被调度进入运行态
LOS_TaskCreateOnly创建任务并阻塞,任务恢复前不会将其加入就绪队列中
LOS_TaskDelete删除指定的任务,回收其任务控制块和任务栈所消耗的资源
表2 任务的状态控制
接口名接口描述
LOS_TaskResume恢复挂起的任务
LOS_TaskSuspend挂起指定的任务,该任务将从就绪任务队列中移除
LOS_TaskJoin阻塞当前任务,等待指定任务运行结束并回收其资源
LOS_TaskDetach修改任务的 joinable 属性为 detach 属性,detach 属性的任务运行结束会自动回收任务控制块资源
LOS_TaskDelay延迟当前任务的执行,在延后指定的时间(tick数)后可以被调度
LOS_TaskYield将当前任务从具有相同优先级的任务队列,移动到就绪任务队列的末尾
表3 任务调度
接口名接口描述
LOS_TaskLock锁定任务调度,阻止任务切换
LOS_TaskUnlock解锁任务调度。通过该接口可以使任务锁数量减1,若任务多次加锁,那么 任务调度在锁数量减为0时才会完全解锁
LOS_GetTaskScheduler获取指定任务的调度策略
LOS_SetTaskScheduler设置指定任务的调度参数,包括优先级和调度策略
LOS_Schedule触发主动的任务调度
表4 任务相关信息获取
接口名接口描述
LOS_CurTaskIDGet获取当前任务的ID
LOS_TaskInfoGet获取指定任务的信息
LOS_GetSystemTaskMaximum获取系统支持的最大任务数
表5 任务优先级
接口名接口描述
LOS_CurTaskPriSet设置当前正在运行的任务的优先级
LOS_TaskPriSet设置指定任务的优先级
LOS_TaskPriGet获取指定任务的优先级
表6 任务绑核操作
接口名接口描述
LOS_TaskCpuAffiSet绑定指定任务到指定CPU上运行,仅在多核下使用
LOS_TaskCpuAffiGet获取指定任务的绑核信息,仅在多核下使用

开发流程

任务的典型开发流程:

  1. 通过LOS_TaskCreate创建一个任务。

    • 指定任务的执行入口函数
    • 指定任务名
    • 指定任务的栈大小
    • 指定任务的优先级
    • 指定任务的属性,LOS_TASK_ATTR_JOINABLE和LOS_TASK_STATUS_DETACHED属性
    • 多核运行时,可以选择设置任务的绑核属性
  2. 任务参与调度运行,执行用户指定的业务代码。

  3. 任务执行结束,如果设置了 LOS_TASK_STATUS_DETACHED 属性,则自动回收任务资源,如果任务设置了 LOS_TASK_ATTR_JOINABLE 属性,则需要调用LOS_TaskJoin 回收任务资源,默认为 LOS_TASK_STATUS_DETACHED 属性。

说明:

  • 内核态具有最高权限,可以操作任意进程内的任务。
  • 用户态进程通过系统调用进入内核态后创建的任务属于KProcess, 不属于当前用户态进程。

编程实例

代码实现如下(该示例代码的测试函数可以加在 kernel /liteos_a/testsuites /kernel /src /osTest.c 中的 TestTaskEntry 中进行测试。):

UINT32 g_taskLoID;
UINT32 g_taskHiID;
#define TSK_PRIOR_HI 4
#define TSK_PRIOR_LO 5
UINT32 ExampleTaskHi(VOID)
{UINT32 ret;PRINTK("Enter TaskHi Handler.\n");/* 延时2个Tick,延时后该任务会挂起,执行剩余任务中最高优先级的任务(g_taskLoID任务) */ret = LOS_TaskDelay(2);if (ret != LOS_OK) {PRINTK("Delay Task Failed.\n");return LOS_NOK;}/* 2个Tick时间到了后,该任务恢复,继续执行 */PRINTK("TaskHi LOS_TaskDelay Done.\n");/* 挂起自身任务 */ret = LOS_TaskSuspend(g_taskHiID);if (ret != LOS_OK) {PRINTK("Suspend TaskHi Failed.\n");return LOS_NOK;}PRINTK("TaskHi LOS_TaskResume Success.\n");return LOS_OK;
}/* 低优先级任务入口函数 */
UINT32 ExampleTaskLo(VOID)
{UINT32 ret;PRINTK("Enter TaskLo Handler.\n");/* 延时2个Tick,延时后该任务会挂起,执行剩余任务中就高优先级的任务(背景任务) */ret = LOS_TaskDelay(2);if (ret != LOS_OK) {PRINTK("Delay TaskLo Failed.\n");return LOS_NOK;}PRINTK("TaskHi LOS_TaskSuspend Success.\n");/* 恢复被挂起的任务g_taskHiID */ret = LOS_TaskResume(g_taskHiID);if (ret != LOS_OK) {PRINTK("Resume TaskHi Failed.\n");return LOS_NOK;}PRINTK("TaskHi LOS_TaskDelete Success.\n");return LOS_OK;
}
/* 任务测试入口函数,在里面创建优先级不一样的两个任务 */
UINT32 ExampleTaskCaseEntry(VOID)
{UINT32 ret;TSK_INIT_PARAM_S initParam = {0};/* 锁任务调度 */LOS_TaskLock();PRINTK("LOS_TaskLock() Success!\n");/* 高优先级任务的初始化参数,其资源回收需要其他任务调用 LOS_TaskJoin */initParam.pfnTaskEntry = (TSK_ENTRY_FUNC)ExampleTaskHi;initParam.usTaskPrio = TSK_PRIOR_HI;initParam.pcName = "HIGH_NAME";initParam.uwStackSize = LOS_TASK_MIN_STACK_SIZE;initParam.uwResved   = LOS_TASK_ATTR_JOINABLE;/* 创建高优先级任务,由于锁任务调度,任务创建成功后不会马上执行 */ret = LOS_TaskCreate(&g_taskHiID, &initParam);if (ret != LOS_OK) {LOS_TaskUnlock();PRINTK("ExampleTaskHi create Failed! ret=%d\n", ret);return LOS_NOK;}PRINTK("ExampleTaskHi create Success!\n");/* 低优先级任务的初始化参数,任务结束后会自行结束销毁 */initParam.pfnTaskEntry = (TSK_ENTRY_FUNC)ExampleTaskLo;initParam.usTaskPrio = TSK_PRIOR_LO;initParam.pcName = "LOW_NAME";initParam.uwStackSize = LOS_TASK_MIN_STACK_SIZE;initParam.uwResved   = LOS_TASK_STATUS_DETACHED;/* 创建低优先级任务,由于锁任务调度,任务创建成功后不会马上执行 */ret = LOS_TaskCreate(&g_taskLoID, &initParam);if (ret!= LOS_OK) {LOS_TaskUnlock();PRINTK("ExampleTaskLo create Failed!\n");return LOS_NOK;}PRINTK("ExampleTaskLo create Success!\n");/* 解锁任务调度,此时会发生任务调度,执行就绪列表中最高优先级任务 */LOS_TaskUnlock();ret = LOS_TaskJoin(g_taskHiID, NULL);if (ret != LOS_OK) {PRINTK("Join ExampleTaskHi Failed!\n");} else {PRINTK("Join ExampleTaskHi Success!\n");}while(1){};return LOS_OK;
}
c

编译运行得到的结果为:

LOS_TaskLock() Success!
ExampleTaskHi create Success!
ExampleTaskLo create Success!
Enter TaskHi Handler.
Enter TaskLo Handler.
TaskHi LOS_TaskDelay Done.
TaskHi LOS_TaskSuspend Success.
TaskHi LOS_TaskResume Success.
TaskHi LOS_TaskDelete Success.
Join ExampleTaskHi Success!

以上就是本篇文章所带来的鸿蒙开发中一小部分技术讲解;想要学习完整的鸿蒙全栈技术。可以在结尾找我可全部拿到!
下面是鸿蒙的完整学习路线,展示如下:
1

除此之外,根据这个学习鸿蒙全栈学习路线,也附带一整套完整的学习【文档+视频】,内容包含如下

内容包含了:(ArkTS、ArkUI、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、鸿蒙南向开发、鸿蒙项目实战)等技术知识点。帮助大家在学习鸿蒙路上快速成长!

鸿蒙【北向应用开发+南向系统层开发】文档

鸿蒙【基础+实战项目】视频

鸿蒙面经

2

为了避免大家在学习过程中产生更多的时间成本,对比我把以上内容全部放在了↓↓↓想要的可以自拿喔!谢谢大家观看!
3

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

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

相关文章

群晖使用Docker部署WPS Office并实现异地使用浏览器制作办公文档

文章目录 前言1. 本地环境配置2. 制作本地分享链接3. 制作公网访问链接4. 公网ip地址访问您的分享相册5. 制作固定公网访问链接 前言 想象一下这个场景:如果遇到周末紧急需要改方案,但团队成员都在各自家中,这个时候如果大家能够轻松访问这个…

Unity图形用户界面!*★,°*:.☆( ̄▽ ̄)/$:*.°★* 。(万字解析)

Unity 3D GUI 简介 游戏开发过程中,开发人员往往会通过制作大量的图形用户界面( Graphical User Interface,GUI )来增强游戏与玩家的交互性。 Unity 3D 中的图形系统分为 OnGUI、NGUI、UGUI等,这些类型的图形系统内容…

仓颉编程入门2,启动HTTP服务

上一篇配置了仓颉sdk编译和运行环境,读取一个配置文件,并把配置文件简单解析了一下。 前面读取配置文件,使用File.readFrom(),这个直接把文件全部读取出来,返回一个字节数组。然后又创建一个字节流,给文件…

Apache James配置连接达梦数据库

项目场景: Apache James配置连接达梦数据库,其他配置中不存在的数据库也可参考此方案。 配置步骤 1、把需要的jar包导入到James 把DmJdbcDriver18.jar复制到下面lib目录下 james-2.3.2\lib 2、 修改连接配置 james-2.3.2\apps\james\SAR-INF\confi…

Dockerfile部署xxljob

使用Dockerfile部署xxljob 1. 背景 我们在使用定时任务调度时,通常会使用xxljob容器化部署xxljob,通常使用 docker pull xuxueli/xxl-job-admin:2.4.0 拉取镜像并启动容器。这种方式对于x86架构服务器来说,没有任何问题。但是在arm架构的服…

springboot项目引入了第三方jar包

应该把jar包放在resource目录下,新建一个lib目录放进去,不然打包的时候会报错找不到jar包,放入jar包,右键添加到库,才可以使用。 _g().startMarquee();

MapReduce基本原理

目录 整体执行流程​ Map端执行流程 Reduce端执行流程 Shuffle执行流程 整体执行流程 八部曲 读取数据--> 定义map --> 分区 --> 排序 --> 规约 --> 分组 --> 定义reduce --> 输出数据 首先将文件进行切片(block)处理&#xff…

【C语言】猜数字游戏

个人主页 : zxctscl 如有转载请先通知 文章目录 前言1. 随机数生成1.1 rand1.2 srand1.3 time1.4 设置随机数的范围 2. 猜数字游戏实现2.1 游戏菜单2.2 主函数部分2.3 game函数部分2.4 附代码2.5 优化代码 前言 前面学习的这些知识,我们就可以写一些稍微…

常见统计量与其抽样分布

什么是统计量 我们首先给出统计量的定义:设 X 1 , X 2 , ⋯ , X n X_1,X_2,\cdots,X_n X1​,X2​,⋯,Xn​ 为来自于总体X的一个样本, g ( X 1 , X 2 , ⋯ , X n ) g(X_1,X_2,\cdots,X_n) g(X1​,X2​,⋯,Xn​) 为关于 X 1 , X 2 , ⋯ , X n X_1,X_2,\cdots,X_n X…

C++ STL容器(三) —— 迭代器底层剖析

本篇聚焦于STL中的迭代器,同样基于MSVC源码。 文章目录 迭代器模式应用场景实现方式优缺点 UML类图代码解析list 迭代器const 迭代器非 const 迭代器 vector 迭代器const 迭代器非const迭代器 反向迭代器 迭代器失效参考资料 迭代器模式 首先迭代器模式是设计模式中…

linux网络编程7

24.9.24学习目录 一.网络通信过程(续)1.路由器 二.原始套接字(SOCK_RAW)1.创建原始套接字2.数据包解析 一.网络通信过程(续) 1.路由器 路由器是用于连接多个逻辑上分开的网络; 具有判断网络地…

React-Native 中使用 react-native-image-crop-picker 在华为手机上不能正常使用拍照功能

背景: React-Native 0.66 中使用 react-native-image-crop-picker 在安卓 华为手机上不能正常使用拍照功能, 其他品牌正常 代码如下: import ImagePicker from react-native-image-crop-picker;ImagePicker.openCamera(photoOptions).then(image > {callback(image);}) …

不靠学历,不拼年资,怎么才能月入2W?

之前统计局发布了《2023年城镇单位就业人员年平均工资情况》,2023年全国城镇非私营单位和私营单位就业人员年平均工资分别为120698元和68340元。也就是说在去年非私营单位就业人员平均月薪1W,而私营单位就业人员平均月薪只有5.7K左右。 图源:…

DownShift: Tuning Shift Reduction With Reliability for Racetrack Memories

目录 DownShift: Tuning Shift Reduction With Reliability for Racetrack Memories文章摘要:文章的主要贡献包括:文章的结构如下:DownShiftDownShift通过以下方式改进了现有的数据放置策略: GROGU(Generating Reliabi…

简单题94. 二叉树的中序遍历 (python)20240921

问题描述: python: # Definition for a binary tree node. # class TreeNode(object): # def __init__(self, val0, leftNone, rightNone): # self.val val # self.left left # self.right right class Solution(object…

【重学 MySQL】三十七、聚合函数

【重学 MySQL】三十七、聚合函数 基本概念5大常用的聚合函数COUNT()SUM()AVG()MAX()MIN() 使用场景注意事项示例查询 聚合函数(Aggregate Functions)在数据库查询中扮演着至关重要的角色,特别是在处理大量数据时。它们能够对一组值执行计算&a…

图书管理系统实现

图书管理系统实现 图书管理系统作用图书管理系统绘图创建Book创建BookListOperation包下代码User包AdminUserNomalUser Main方法整体代码(带有注释)Opertaion包下的代码IOpertaion(接口)Add添加图书代码Dele删除图书代码Borrow借阅…

PyTorch 池化层详解

在深度学习中,池化层(Pooling Layer)是卷积神经网络(CNN)中的关键组成部分。池化层的主要功能是对特征图进行降维和减少计算量,同时增强模型的鲁棒性。本文将详细介绍池化层的作用、种类、实现方法&#xf…

C++——多线程编程(从入门到放弃)

进程:运行中的程序 线程:进程中的进程 线程的最大数量取决于CPU的核心数 一、将两个函数添加到不同线程中 demo:两个函数test01()和test02(),实现将用户输入的参数进行打印输出1000次 将这两个函数均放到独立的线程t1和t2中&…

vue3+element-plus icons图标选择组件封装

一、最终效果 二、参数配置 1、代码示例 <t-select-icon v-model"selectVlaue" />2、配置参数&#xff08;Attributes&#xff09;继承 el-input Attributes 参数说明类型默认值v-model绑定值string-prefixIcon输入框前缀iconstringSearchisShowSearch是否显…