ostaskcreate函数作用_认识上中下

ostaskcreate函数作用_认识上中下OSTaskCreate()是学习ucos-Ⅱ操作系统的第一个函数,费了九牛二虎之力,现在感觉差不多可以过了。#ifOS_TASK_CREATE_EN>0INT8UOSTaskCreate(void(*task)(void*p_arg),void*p_arg,OS_STK*ptos,INT8Uprio)/*1*/{ OS_STK…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 OSTaskCreate()是学习ucos-Ⅱ操作系统的第一个函数,费了九牛二虎之力,现在感觉差不多可以过了。


#if OS_TASK_CREATE_EN > 0
INT8U  OSTaskCreate (void (*task)(void *p_arg), void *p_arg, OS_STK *ptos, INT8U prio)/*1*/
{						
    OS_STK    *psp;								/*2*/
    INT8U      err;
	
#if OS_CRITICAL_METHOD == 3                  					/*3*/
    OS_CPU_SR  cpu_sr = 0;
#endif

#if OS_ARG_CHK_EN > 0
    if (prio > OS_LOWEST_PRIO) 
    {              
        return (OS_ERR_PRIO_INVALID);						/*4*/
    }
#endif
	
    OS_ENTER_CRITICAL();
    if (OSIntNesting > 0) 							/*5*/												
    {                  
        OS_EXIT_CRITICAL();
        return (OS_ERR_TASK_CREATE_ISR);
    }
    if (OSTCBPrioTbl[prio] == (OS_TCB *)0)					/*6*/
    {  
        OSTCBPrioTbl[prio] = OS_TCB_RESERVED; 					/*7*/
                                              
        OS_EXIT_CRITICAL();
		
        psp = OSTaskStkInit(task, p_arg, ptos, 0);    				/*8*/
		
        err = OS_TCBInit(prio, psp, (OS_STK *)0, 0, 0, (void *)0, 0);		/*9*/
        if (err == OS_ERR_NONE) 
	{
            if (OSRunning == OS_TRUE) 						/*10*/
	    {       
                OS_Sched();							/*11*/
            }
        } 
	else
	{
            OS_ENTER_CRITICAL();
            OSTCBPrioTbl[prio] = (OS_TCB *)0;	 				/*12*/
            OS_EXIT_CRITICAL();
        }
        return (err);
    }
    else
    {
	OS_EXIT_CRITICAL();
	return (OS_ERR_PRIO_EXIST);						/*13*/
    }
}
#endif

/*1*/

void (*task)(void *p_arg):首先是个函数指针。在调用该函数时,将该任务的函数名(即该任务所占内存的首地址)作为指针传递过来;

void *p_arg:传递的任务参数,一般不用;

OS_STK *ptos,:该任务的堆栈的栈顶指针(堆栈增长的默认方向从上往下,从高地址往低地址);

INT8U prio:该任务的优先级。

/*2*/

OS_STK    *psp:定义一个堆栈类型的指针(该指针一直指向这个任务堆栈的栈顶,也称栈顶指针)。

/*3*/

OS_CPU_SR  cpu_sr = 0:定义一个OS_CPU_SR类型的cpu_sr的局部变量,

该变量描述cpu的状态寄存器的,每次屏蔽中断时,都将cpu状态寄存器的值存进cpu_sr这个变量中,每次打开中断时,再将cpu_sr的值赋值给cpu的状态寄存器。

/*4*/

prio > OS_LOWEST_PRIO:定义的优先级应在允许的范围内,否则不具备有效性。

/*5*/

OSIntNesting > 0:在中断处理程序中,不应进行任务创建,每次进入中断的时候,OSIntNesting ++,若大于0,必然在处理中断程序。

/*6*/

OSTCBPrioTbl[prio]:任务优先级列表是一个数组指针,该数组元素指向该任务控制块的内存地址;

(OS_TCB *)0:表示一个OS_TCB类型的指针,指向0,是一个空指针;

OSTCBPrioTbl[prio] == (OS_TCB *)0:该数组元素指向的内存地址是一个空地址,还没有被使用。

/*7*/

OS_TCB_RESERVED:即(OS_TCB *)1:表示一个OS_TCB类型的指针,指向1,表示非空指针;

OSTCBPrioTbl[prio] == (OS_TCB *)1, 该数组元素指向的内存地址是一个非空地址了,已经被占用了,还没有赋予具体的内存地址,这是一个宣告。

/*8*/

任务堆栈的初始化,并返回当前任务堆栈的栈顶指针。这个函数让我正确认识了堆栈的规则   后进先出,详情见OSTaskStkInit()函数。

/*9*/

任务控制块的初始化,并返回初始化的结果状态。详情见OS_TCBInit()函数。

/*10*/

OSRunning == OS_TRUE:操作系统的状态必须在运行的状态下,才能进行任务调度。操作系统运行过程中,OSRunning 第一次置为OS_TRUE状态是在OSStart()函数中实现的。


/*11*/

OS_Sched():进行任务调度。 详情见 OS_Sched()函数。

/*12*/

OSTCBPrioTbl[prio] = (OS_TCB *)0:若任务控制块初始化不成功,则释放被宣告占有的任务控制块。

/*13*/

return (OS_ERR_PRIO_EXIST):说明该任务控制块的内存地址已经被占用了,或者说该优先级已经被占用了。

上面是我对OSTaskCreate()函数的一些细节的认识,若有理解不对的地方,恳请指正!

好了,第一次写博希望大家多多支持!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196945.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • vue引入js文件并使用_css引入js

    vue引入js文件并使用_css引入js1.处理js文件,注意格式,一定要export,否则获取到的为null2.在Vue中引入jsimportallinfofrom”../../../../static/js/allinfo.js”;3.使用js中的数据vardata=allinfo.属性名称;

    2022年10月8日
    4
  • 使用OleDbDataAdapter更新Access

    使用OleDbDataAdapter更新Accesstry{MdbDALdal=newMdbDAL();DataTabledt=(DataTable)gv.DataSource;IDbCommandcmd=dal.NewDbCommand(string.Format(“UPDATE{0}SET[Msg]=@Msg,[MsgChs]=@MsgChs,[MsgCht]=@MsgChtWH…

    2025年6月26日
    2
  • 打开GTA 5竟要跑19.8亿次if语句!黑客嘲讽R星代码烂,修改后直接省70%加载时间

    打开GTA 5竟要跑19.8亿次if语句!黑客嘲讽R星代码烂,修改后直接省70%加载时间本文转载自量子位一支烟的功夫,GTA5联机版终于打开了。「7年了!GTA5联机版加载还是这么慢??」△PleasewaitforevertoplayReddit、Steam、HackerNews上,无数玩家吐槽抱怨……进游戏少则等5、6分钟,多则20分钟。终于,一个黑客大哥实在忍不了,用逆编译器逐条查看运行情况,终于找到原因。原来,R星(游戏开发商RockStar)写的代码太低效,加载时,一个if语句竟然循环了19.8亿次….幕后黑手:谁占用大量时间?加

    2022年6月12日
    32
  • java nio 详_java NIO 详解

    java nio 详_java NIO 详解JavaNIO(NewIO)是从Java1.4版本开始引入的一个新的IOAPI,可以替代标准的JavaIOAPI。本系列教程将有助于你学习和理解JavaNIO。JavaNIO提供了与标准IO不同的IO工作方式:ChannelsandBuffers(通道和缓冲区):标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(Buffer)进行操作,数据总…

    2022年7月7日
    20
  • Particle_filter 粒子滤波器 的学习笔记

    Particle_filter 粒子滤波器 的学习笔记粒子滤波是一种基于蒙特卡洛模拟的非线性滤波方法,其核心思想是用随机采样的粒子表达概率密度分布。粒子滤波的三个重要步骤为:1)粒子采样,从建议分布中抽取一组粒子;2)粒子加权,根据观测概率分布,重要

    2022年8月6日
    2
  • html中table美化,漂亮的css table样式「建议收藏」

    html中table美化,漂亮的css table样式「建议收藏」工作中发邮件通知人员样式总是一个麻烦事,工作的严肃性不能让邮件样式太花哨,但是又不能太简陋,所以找了下面的table样式和大家分享。效果如下图所示:漂亮CSSTables-幸凡学习网body{font:normal11pxauto”TrebuchetMS”,Verdana,Arial,Helvetica,sans-serif;color:#4f6b72;backgroun…

    2022年9月20日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号