新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > ucos-ii學(xué)習(xí)筆記——消息郵箱的原理及使用

ucos-ii學(xué)習(xí)筆記——消息郵箱的原理及使用

作者: 時間:2016-11-28 來源:網(wǎng)絡(luò) 收藏
Createdon:2012-10-7

Author:zhangbin

本文引用地址:http://m.butianyuan.cn/article/201611/322850.htm

學(xué)習(xí)筆記

forucos-iiPC

redesignedbyzhangbin

2012-10-7

versions:V-0.1

AllRightsReserved

#include"INCLUDES.h"

#defineTASK_STK_SIZE512

char*s;//MyTask發(fā)送消息的指針

char*ss;//YouTask接受到的消息的指針

INT8Uerr;

INT8Uy=0;

INT32UTimes=0;

OS_EVENT*Str_Box;//定義事件控制塊指針定義消息郵箱的指針

//比較和上例中定義信號量的區(qū)別OS_EVENT*Fun_Semp;//聲明信號量是事件控制塊ECB類型的

//其實沒有什么區(qū)別,定義的類型都是OS_EVENT的指針,都是事件控制塊的指針

OS_STKStartTaskStk[TASK_STK_SIZE];//定義任務(wù)堆棧區(qū)

OS_STKMyTaskStk[TASK_STK_SIZE];

OS_STKYouTaskStk[TASK_STK_SIZE];

voidStartTask(void*data);

voidMyTask(void*data);

voidYouTask(void*data);

voidmain(void)

{

OSInit();

PC_DOSSaveReturn();

PC_VectSet(uCOS,OSCtxSw);

Str_Box=OSMboxCreate((void*)0);//創(chuàng)建消息郵箱返回值是指向創(chuàng)建消息郵箱的指針

//該函數(shù)的參數(shù)為void*msg是消息指針,在這里(void*)0表示初始值為NULL這樣也就表示

//新創(chuàng)建的這個消息郵箱里沒有內(nèi)容

OSTaskCreate(StartTask,(void*)0,&StartTaskStk[TASK_STK_SIZE-1],0);//創(chuàng)建起始函數(shù)

OSStart();

}

voidStartTask(void*pdata)

{

#ifOS_CRITICAL_METHOD==3

OS_CPU_SRcpu_sr;

#endif

INT16Skey;

pdata=pdata;

OS_ENTER_CRITICAL();

PC_VectSet(0x08,OSTickISR);

PC_SetTickRate(OS_TICKS_PER_SEC);

OS_EXIT_CRITICAL();

OSStatInit();

OSTaskCreate(MyTask,(void*)0,&MyTaskStk[TASK_STK_SIZE-1],1);//創(chuàng)建任務(wù)函數(shù)

OSTaskCreate(YouTask,(void*)0,&YouTaskStk[TASK_STK_SIZE-1],2);//創(chuàng)建任務(wù)函數(shù)

for(;;)

{

//如果恩下ESC鍵,則退出UC/OS-II

if(PC_GetKey(&key)==TRUE)

{

if(key==0x1B)

{

PC_DOSReturn();

}

}

OSTimeDlyHMSM(0,0,3,0);

}

}

voidMyTask(void*pdata)

{

#ifOS_CRITICAL_METHOD==3

OS_CPU_SRcpu_sr;

#endif

pdata=pdata;

for(;;)

{

sprintf(s,"%d",Times);//把Times賦給s

OSMboxPost(Str_Box,s);//發(fā)送消息s其中兩個參數(shù)Str_Box是OS_EVENT*pevent表示消

//息郵箱指針(是事件控制塊指針),s是void*msg表示消息指針

//該函數(shù)表示把消息s發(fā)送到消息郵箱Str_Box中

Times++;//MyTask的運行次數(shù)加1

OSTimeDlyHMSM(0,0,1,0);

}

}

voidYouTask(void*pdata)

{

#ifOS_CRITICAL_METHOD==3//AllocatestorageforCPUstatusregister

OS_CPU_SRcpu_sr;

#endif

pdata=pdata;

for(;;)

{

ss=OSMboxPend(Str_Box,10,&err);//請求消息郵箱參數(shù)表示:Str_Box是消息郵箱指針,10表示等待時間,

//err表示錯誤信息,返回值ss是郵箱中的消息指針

PC_DispStr(10,++y,ss,DISP_BGND_BLACK+DISP_FGND_WHITE);//顯示消息的內(nèi)容,就是任務(wù)MyTask的運行次數(shù)

OSTimeDlyHMSM(0,0,1,0);//等待1s

}

}

//本程序?qū)崿F(xiàn)的功能就是MyTask把自己的運行次數(shù)作為消息發(fā)送到消息郵箱中,任務(wù)YouTask請求消息郵箱,得到消息并顯示出來

//因為MyTask和YouTask的等待時間相等,都是1s,所以Mytask和YouTask交替運行,運行次數(shù)相同,所以顯示出的數(shù)字是從

//0開始,123

//我試過了,(1)當(dāng)MyTask的延遲時間短時,即YouTask運行一次,MyTask運行多次,這樣顯示的數(shù)字就是MyTask的運行次數(shù),會不連續(xù)

//這是正常的。

//但是,(2)當(dāng)MyTask運行一次,YouTask運行多次時,這樣會好幾次顯示同樣的數(shù)字,這也就表示在YouTask調(diào)用

//ss=OSMboxPend(Str_Box,10,&err);函數(shù)后,取得了消息,并每有把消息郵箱中的消息給清除,而是消息一直在郵箱中存在,

//所以下次再取消息的時候,消息還沒有來得及更新,還是原來的消息。

//不知道當(dāng)調(diào)用ss=OSMboxPend(Str_Box,10,&err);取得消息后,郵箱中的消息是否應(yīng)該清除,從上面的現(xiàn)象來看,好像是沒有清除

//這要分析該函數(shù)的代碼才能搞清楚

//清楚了,情況是這樣的:函數(shù)ss=OSMboxPend(Str_Box,10,&err);得到了郵箱中的消息后,確實是將郵箱清除了,將NULL指針存入了

//郵箱中,當(dāng)出現(xiàn)上面(2)情況時,郵箱為空,YouTask是處于等待狀態(tài),但是由于在調(diào)用OSMboxPend時指定等待時間為10,所以當(dāng)

//等待時間到了,即使郵箱中還是無消息,YouTask也會進(jìn)入就緒態(tài)的,然后繼續(xù)往下運行,但是,由于ss沒有再取得新的消息,還

//是原來的值,所以還會顯示原來的值。這種情況可以用改變OSMboxPend的等待時間來驗證。OSMboxPend的詳細(xì)代碼說明,參見P235

//但是不知道為什么當(dāng)OSMboxPend的等待時間我設(shè)為0時,表示無限等待,知道郵箱中有消息,就什么也不顯示了,為什么???

//當(dāng)?shù)却龝r間設(shè)為很大,大于1s對應(yīng)的等待時間,顯示的時間間隔就由等待時間來確定了,不知道為什么會這樣??

//這個要搞清楚



評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉