在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

使用RTOS的好處呢?

傳感器技術 ? 來源:面包板社區 ? 作者:面包板社區 ? 2021-01-04 11:09 ? 次閱讀

要用RTOS?單片機就這一點資源,使用RTOS能保證效率嗎?”

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

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

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

第一種方法,在中斷中處理協議:

unsignedcharBuf[NBYTE-2];bitGetRight=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;}}}

第二種方法,使用隊列中斷函數:

voidcomm(void)interrupt4//"串行口中斷"{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=隊列首字節;if(temp!=STARTBYTE2) return 0;出隊 temp;sum=STARTBYTE1+STARTBYTE2;for(i=0;i{temp=隊列首字節;if(temp==STARTBYTE1){temp=隊列次首字節;if(temp==STARTBYTE2) return 0;}出隊 temp;*cp++=temp;Sum+=temp;}temp=隊列首字節;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語句,程序更加簡單易讀),第二種次之(因為要編隊列程序),第一種最差。如果協議更加復雜,這方面更加明顯。程序簡單易讀,自然出錯機會小了。

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

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

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

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

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

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

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

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

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

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

責任編輯:lq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 單片機
    +關注

    關注

    6044

    文章

    44632

    瀏覽量

    639285
  • 編程
    +關注

    關注

    88

    文章

    3642

    瀏覽量

    94076
  • RTOS
    +關注

    關注

    22

    文章

    821

    瀏覽量

    119944

原文標題:單片機就那點資源,為啥還要用RTOS?

文章出處:【微信號:WW_CGQJS,微信公眾號:傳感器技術】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Flexible Safety RTOS的技術特征

    Embedded Office的Flexible Safety RTOS是專為具有嚴格功能安全要求的嵌入式系統量身定制的、先進的實時操作系統。該RTOS專為工業自動化、汽車、鐵路和醫療設備等行業而設
    的頭像 發表于 01-07 11:29 ?337次閱讀

    深入解析Zephyr RTOS的技術細節

    Zephyr是一個針對資源受限設備優化的小型、可縮放、多體系架構實時操作系統(RTOS)。Zephyr由Linux基金會維護[1],是一個以構建業界最佳的RTOS為目標的開源合作項目。近年來
    的頭像 發表于 10-22 16:47 ?810次閱讀
    深入解析Zephyr <b class='flag-5'>RTOS</b>的技術細節

    rtthread是搶占式的rtos,那么線程的timeout參數具體的作用是什么

    查閱相關說明,rtthread是搶占式的rtos,那么線程的timeout參數具體的作用是什么, 假如線程A,B的優先級分別是1和2,timeout是10ms。當線程B 在運行中,還未到timeout,此刻掛起的線程A被觸發,是直接搶占,打斷線程B的運行還是要等超時再運
    發表于 09-27 08:39

    RTOS正在縮小與Linux的差距

    RTOS與Linux的物聯網設備操作系統之爭已經持續了很多年。Linux以其強大的計算能力和豐富的軟件生態,在需要復雜處理和軟件支持的物聯網設備上占據一席之地;RTOS憑借實時響應和資源節約的特性
    的頭像 發表于 09-10 08:07 ?864次閱讀
    <b class='flag-5'>RTOS</b>正在縮小與Linux的差距

    freertos和rtos區別是什么

    FreeRTOS 和 RTOS(實時操作系統)是兩個不同的概念,但它們之間有緊密的聯系。FreeRTOS 是一個特定的開源實時操作系統,而 RTOS 是實時操作系統的一般概念。 概念定義 RTOS
    的頭像 發表于 09-02 14:18 ?1623次閱讀

    RTOS與Linux有什么區別

    RTOS(Real-Time Operating System,實時操作系統)與Linux是兩種在不同應用場景下發揮重要作用的操作系統,它們在設計理念、功能特性、應用場景以及性能表現等方面存在顯著差異。以下是對RTOS與Linux區別的詳細分析。
    的頭像 發表于 08-20 16:05 ?4424次閱讀

    RTOS的特性和類型

    實時操作系統(RTOS)是一種可運行實時計算應用程序的軟件平臺,用于處理具有明確時間約束的事件和數據。與通用操作系統(GPOS)不同,RTOS必須在有限的硬件資源上調度應用程序之間的處理和數據共享
    的頭像 發表于 08-20 11:29 ?746次閱讀

    RTOS開發最佳實踐

    基于RTOS編寫應用程序時,有一些要注意事項。在本節中,您將學習RTOS開發最佳實踐,例如POSIX合規性、安全性和功能安全認證。
    的頭像 發表于 08-20 11:24 ?534次閱讀

    RTOS-SDK下如何關閉系統的提示信息?

    您好,我使用的1.3版本的RTOS-SDK,在STA狀態下,連接狀態改變串口0會有提示信息產生,怎么樣才能將其關閉
    發表于 07-22 07:04

    esp8266_rtos_sdk串口初始化異常是什么原因

    硬件環境:nodeMCU 我從github下載了最新的RTOS SDK,并且僅僅在初始化 user_init() 函數里添加了一個函數 uart_init_new() 然后編譯。生成bin文件,下載
    發表于 07-11 06:04

    將ADF移植到RTOS上大概都需要哪些步驟?一般移植周期多久?

    1 ADF是免費的開源軟件嗎? 2 將ADF移植到RTOS上大概都需要哪些步驟?一般移植周期多久?
    發表于 06-28 08:03

    通過git命令獲取ESP8266_RTOS_SDK失敗如何解決?

    本人使用的硬件平臺為esp8266,開發環境為ubuntu22.04。在通過git命令獲取ESP8266_RTOS_SDK失敗,通過上網搜索嘗試了很多方法無效。具體情況如下
    發表于 06-07 07:26

    FreeRtos能否直接讀取Rtos的系統時鐘計數器來實現延時統計,改如何讀取?

    關于200~300uS的延時 1 能否直接讀取Rtos的 系統時鐘計數器來 實現延時統計,改如何讀取? 2 通過獨立的定時器中斷來實現,這樣感覺有點麻煩,好處是比較嚴謹,但是代碼稍微復雜 3
    發表于 04-29 08:40

    不會RTOS,是因為你沒搞懂NVIC

    管理的中斷可進行中斷嵌套,直譯為高優先級可打斷低優先級中斷,然后高優先級執行完了再轉回去執行低優先級中斷。對于RTOS(實時操作系統)類型的OS有很大的好處,所以
    的頭像 發表于 03-31 08:09 ?1224次閱讀
    不會<b class='flag-5'>RTOS</b>,是因為你沒搞懂NVIC

    基于RTOS的應用進程中的典型線程

    RTOS中的關鍵因素是最小的中斷延遲和最小的線程切換延遲。RTOS的價值在于它的響應速度或可預測性,而不是它在給定時間段內可以執行的工作量。
    發表于 03-05 09:32 ?714次閱讀
    基于<b class='flag-5'>RTOS</b>的應用進程中的典型線程
    主站蜘蛛池模板: 欧美宗合网 | 四虎影视永久在线 yin56xyz | a毛片网站 | 韩国男女无遮挡高清性视频 | 久久成人精品免费播放 | 亚洲狼色专区 | 一区二区在线免费视频 | 午夜高清在线观看免费6 | 日韩基地1024首页 | 一区二区三区四区欧美 | 激情五月社区 | 91视频精品 | 免费观看影院 | 伊人免费网 | 狠狠色丁香婷婷久久综合不卡 | 国产一级毛片午夜福 | 伊人久久大杳蕉综合大象 | 特级aaa片毛片免费观看 | 国产色综合天天综合网 | 免费观看a毛片一区二区不卡 | 四虎www成人影院免费观看 | 网站四虎1515hhcom | 国产69精品久久久久9999 | 91激情网| 一级毛片在线不卡直接观看 | 亚洲综合色婷婷久久 | 超级毛片 | 狠狠噜天天噜日日噜 | 农村一级片 | 日韩特级毛片免费观看视频 | 狠狠狠狠狠狠 | 欧美性受xxxx极品 | 丁香婷婷色综合 | 爽a中文字幕一区 | 亚洲国产精品久久久久婷婷软件 | 最新版天堂资源官网 | 伊人久久大香线蕉综合亚洲 | 欧美1819| 免费人成在线 | 在线免费观看色视频 | 国产伦子一区二区三区 |