本帖最后由 电子询问 于 2016-9-8 16:43 编辑
如果按例程那样编写,串口助手中只会显示middle task Running!和low task Running!,然后什么都不显示,无法向原子教程一样模拟信号量被长时间占用的情况,
但如果将low_task函数中的OSSched();改为延时函数OSTimeDlyHMSM(0,0,1,0,OS_OPT_TIME_PERIODIC,&err); 则串口助手显示与教程的实验结果那样先显示middle task Running! low task Running! high task Pend Sem然后一直显示middle task Running!
这是为什么?
修改如下:
void low_task(void *p_arg)
{
static u32 times;
OS_ERR err;
while(1)
{
OSSemPend(&TEST_SEM,0,OS_OPT_PEND_BLOCKING,0,&err);
printf("low task Running!
");
for(times=0;times<20000000;times++)
{
OSSched(); //将这里改成OSTimeDlyHMSM(0,0,1,0,OS_OPT_TIME_PERIODIC,&err);
}
OSSemPost(&TEST_SEM,OS_OPT_POST_1,&err);
OSTimeDlyHMSM(0,0,1,0,OS_OPT_TIME_PERIODIC,&err);
}
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
教程里面说的清清楚楚,这么做是为了模拟信号量被占用!在真实情况中肯定不会这么去写代码。为了让实验效果清晰,特地弄了这么久!
一周热门 更多>