日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > > 充電吧
[導讀]對于搞單片機的特別用8051系列工程師來說,談到單片機的RTOS,很多時候會問一句:“為什么要用RTOS?單片機就這一點資源,使用RTOS能保證效率嗎?”

對于搞單片機的特別用8051系列工程師來說,談到單片機的RTOS,很多時候會問一句:“為什么要用RTOS?單片機就這一點資源,使用RTOS能保證效率嗎?”

對于這個問題,我會反問:“你用單片機的目的是什么?是為了用單片機的C編程,單片機的匯編編程甚至于用單片機的二進制指令編程?”上個世紀80年代,工程師用二進制指令給Z80編程,現在還有誰在用?現在還有人死抱著匯編不放,但越來越多的人工程師使用C編程(我起初也是使用匯編的),為什么?因為我們的目的是在有限的時間甚至是不充足的時間內把項目保質保量的完成!使用是么工具和方法是次要的(如果你的項目以成本放在第一位,則另當別論,這時,也是要考慮開發(fā)時間的)。時間就是金錢啊,一個產品在單片機上增加些許成本是可以接受的。況且,使用8051系列單片機時,單片機資源也常有富余,CPU一般情況也只是空轉,這就為它使用RTOS創(chuàng)造了條件。

那么,使用RTOS的好處呢?我舉一個例子吧。假設我們編一個串行通訊程序,通訊協(xié)議如下:

數據包長度為NBYTE,起始字節(jié)為STARTBYTE1,STARTBYTE2,最后一個字節(jié)為檢驗和,中間字節(jié)不可能出現連續(xù)出現STARTBYTE1,STARTBYTE2。

第一種方法,在中斷中處理協(xié)議:

unsigned char Buf[NBYTE-2];bit GetRight=0;

void comm(void) interrupt 4//"串行口中斷"{

static unsigned char Sum,Flag=0,i;

unsigned char temp;

if(RI==1)

{

RI=0;

temp=SBUF;

switch(Flag)

{

case 0:

if(temp==STARTBYTE1)

{

Flag=1;

}

break;

case 1:

if(temp==STARTBYTE2)

{

Sum=STARTBYTE1+STARTBYTE2;

i=0;

Flag=2;

break;

}

if(temp==STARTBYTE1) break;

Flag=0;

break;

case 2:

if(temp==STARTBYTE1)

{

Flag=3;

break;

}

Sum+=temp;

if((i>=(NBYTE-3))&&Sum==0)

{

GetRight=1;

Flag=0;

break;

}

Buf[i++]=temp;

break;

case 3:

if(temp==STARTBYTE2)

{

Sum=STARTBYTE1+STARTBYTE2;

Flag=2;

i=0;

break;

}

Sum+=STARTBYTE1;

if((i>=(NBYTE-3))&&Sum==0)

{

GetRight=1;

Flag=0;

break;

}

Buf[i++]=STARTBYTE1;

if(temp==STARTBYTE1)

{

break;

}

Sum+=temp;

if((i>=(NBYTE-3))&&Sum==0)

{

GetRight=1;

Flag=0;

break;

}

Buf[i++]=temp;

Flag=2;

break;

}

}}

第二種方法,使用隊列

中斷函數:

void comm(void) interrupt 4//"串行口中斷"{

if(RI==1)

{

RI=0;

SBUF 入隊;

}}

主程序不斷調用的函數:

unsigned char Buf[NBYTE-2];

unsigned char ReadSerial(unsigned char *cp){

unsigned char i;

unsigned char temp,Sum;

temp=隊列中數據個數;

if(temp<(NBYTE)) return 0;

出隊 temp;

if(temp!=STARTBYTE1) return 0;

temp=隊列首字節(jié);

if(temp!=STARTBYTE2) return 0;

出隊 temp;

sum=STARTBYTE1+STARTBYTE2;

for(i=0;i

{

temp=隊列首字節(jié);

if(temp==STARTBYTE1)

{

temp=隊列次首字節(jié);

if(temp==STARTBYTE2) return 0;

}

出隊 temp;

*cp++=temp;

Sum+=temp;

}

temp=隊列首字節(jié);

Sum+=temp;

if(Sum!=0) return 0;

出隊 temp;

return 1;}

第三種方法,使用RTOS

中斷函數:

void comm(void) interrupt 4//"串行口中斷"{

OS_INT_ENTER();

if(RI==1)

{

RI=0;

OSIntSendSignal(RECIVE_TASK_ID);

}

OSIntExit();}

ID為RECIVE_TASK_ID的任務

void Recuve(void){

unsigned char temp,temp1,Sum,i;

OSWait(K_SIG,0);

temp=SBUF;

while(1)

{

while(1)

{

OSWait(K_SIG,0);

temp1=SBUF;

if((temp==STARTBYTE1)&&(temp1==STARTBYTE2)) break;

temp=temp1;

}

Sum=STARTBYTE1+STARTBYTE2;

OSWait(K_SIG,0);

temp=SBUF;

for(i=0;i

{

OSWait(K_SIG,0);

temp1=SBUF;

if((temp==STARTBYTE1)&&(temp1==STARTBYTE2))

{

OSWait(K_SIG,0);

temp=SBUF;

i=-1;

Sum=STARTBYTE1+STARTBYTE2;

continue;

}

Buf[i]=temp;

Sum+=temp;

temp=temp1;

}

Sum+=temp1;

if(Sum==0) OSSendSignal(命令解釋任務 ID);

}}

以下為這幾種方法的比較

可讀性和編程容易性方面,第三鐘方法最好(如果允許使用goto語句,程序更加簡單易讀),第二種次之(因為要編隊列程序),第一種最差。如果協(xié)議更加復雜,這方面更加明顯。程序簡單易讀,自然出錯機會小了。

RAM占用方面,第三種方法較少,第二種最多(因為隊列占用大量空間),第一種最少。

中斷執(zhí)行時間方面,第三種方法最長,第二種最短,第一種較長。

從功能方面,第三種方法最強,它還可以進行超時處理(雖然例子程序沒有),其它方法均不行。

如果數據來的太快,命令處理程序來不及處理,三種方法處理方式不太一樣,第一種和第三種方法類似:丟棄以前數據,第二種則是丟棄后到的數據。而且,第二種方法必須等命令處理程序完成后才處理下一個數據包,而第一種和第三種方只需命令處理程序將數據收取后就可處理下一個數據包。也就是說,第一種和第三種與命令處理程序并行處理,第二種方法為串行處理。

現在,一般情況下,開發(fā)的效率第一,執(zhí)行的效率(包括執(zhí)行時間和資源占用)第二。在這種情況下,降低些許效率換取開發(fā)的效率的較大提高,何樂而不為?何況,單個模塊的執(zhí)行的效率高不等于整個程序執(zhí)行效率高。例如,如果程序需要等待一段時間,一般用程序延時或定時器延時。無論何種方法,CPU不再處理其它工作,效率很低。而用RTOS,等待的時候CPU可以處理其它工作,效率得到提高。

以下摘自《uC/OS-II--源碼公開的實時嵌入式操作系統(tǒng)》

“實時內核也稱為實時操作系統(tǒng)或RTOS。使用它使得實時應用程序的設計和擴展變得容易。不需要大的改動就可以增加新的功能。通過應用程序分割為若干獨立的任務,RTOS使得應用程序的設計過程大為簡化。使用可剝奪性的內核時,所有時間要求苛刻的事件都得到了盡可能快捷、有效的處理。通過有效的服務;如信號量、郵箱、隊列、延時、超時等;RTOS使得資源得到更好的利用。

“如果應用項目對額外的需求可以承受,應該考慮使用實時內核。這些額外的需求是:內核的價格,額外ROM/RAM開銷,2至4百分點的CPU額外負擔。

“還有沒提到的一個因素是使用實時內核增加的價格成本。在一些應用中,價格就是一切,以至于對使用RTOS連想都不敢想。”

總而言之,適用的就是最好的,不要拒絕RTOS,在它適用的情況下,它工作得很好。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

8位單片機在嵌入式設計領域已經成為半個多世紀以來的主流選擇。盡管嵌入式系統(tǒng)市場日益復雜,8位單片機依然不斷發(fā)展,積極應對新的挑戰(zhàn)和系統(tǒng)需求。如今,Microchip推出的8位PIC?和AVR?單片機系列,配備了先進的獨立...

關鍵字: 單片機 嵌入式 CPU

在嵌入式系統(tǒng)開發(fā)中,程序燒錄是連接軟件設計與硬件實現的關鍵環(huán)節(jié)。當前主流的單片機燒錄技術已形成ICP(在電路編程)、ISP(在系統(tǒng)編程)、IAP(在應用編程)三大技術體系,分別對應開發(fā)調試、量產燒錄、遠程升級等不同場景。...

關鍵字: 單片機 ISP ICP IAP 嵌入式系統(tǒng)開發(fā)

在嵌入式系統(tǒng)開發(fā)中,看門狗(Watchdog Timer, WDT)是保障系統(tǒng)可靠性的核心組件,其初始化時機的選擇直接影響系統(tǒng)抗干擾能力和穩(wěn)定性。本文從硬件架構、軟件流程、安全規(guī)范三個維度,系統(tǒng)分析看門狗初始化的最佳實踐...

關鍵字: 單片機 看門狗 嵌入式系統(tǒng)

本文中,小編將對單片機予以介紹,如果你想對它的詳細情況有所認識,或者想要增進對它的了解程度,不妨請看以下內容哦。

關鍵字: 單片機 開發(fā)板 Keil

隨著單片機系統(tǒng)越來越廣泛地應用于消費類電子、醫(yī)療、工業(yè)自動化、智能化儀器儀表、航空航天等各領域,單片機系統(tǒng)面臨著電磁干擾(EMI)日益嚴重的威脅。電磁兼容性(EMC)包含系統(tǒng)的發(fā)射和敏感度兩方面的問題。

關鍵字: 單片機 電磁兼容

以下內容中,小編將對單片機的相關內容進行著重介紹和闡述,希望本文能幫您增進對單片機的了解,和小編一起來看看吧。

關鍵字: 單片機 復位電路

在這篇文章中,小編將為大家?guī)韱纹瑱C的相關報道。如果你對本文即將要講解的內容存在一定興趣,不妨繼續(xù)往下閱讀哦。

關鍵字: 單片機 異常復位

今天,小編將在這篇文章中為大家?guī)韱纹瑱C的有關報道,通過閱讀這篇文章,大家可以對它具備清晰的認識,主要內容如下。

關鍵字: 單片機 仿真器

單片機將是下述內容的主要介紹對象,通過這篇文章,小編希望大家可以對它的相關情況以及信息有所認識和了解,詳細內容如下。

關鍵字: 單片機 中斷 boot

一直以來,單片機都是大家的關注焦點之一。因此針對大家的興趣點所在,小編將為大家?guī)韱纹瑱C的相關介紹,詳細內容請看下文。

關鍵字: 單片機 數字信號 模擬信號
關閉