chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

RTOS任務(wù)的堆棧大小與代碼量有啥關(guān)系嗎?

strongerHuang ? 來(lái)源:strongerHuang ? 作者:strongerHuang ? 2021-05-26 09:34 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

最近有小伙伴問了這樣一個(gè)問題:我有個(gè)任務(wù)中的代碼量很多,是不是這個(gè)任務(wù)的堆棧需要分配很大才行?

下面就圍繞任務(wù)代碼量,以及堆棧進(jìn)行描述相關(guān)內(nèi)容。

1RTOS任務(wù)堆棧分配

市面上很多RTOS的任務(wù)都是需要提前分配堆棧大小,也就是在創(chuàng)建任務(wù)的時(shí)候分配好堆棧的大小。 比如uCOS創(chuàng)建一個(gè)檢測(cè)(Check)任務(wù):

// 任務(wù)優(yōu)先級(jí)#define TASK_CHECK_PRIO 6 // 任務(wù)堆棧大小#define TASK_CHECK_STK_SIZE 128 // 堆棧OS_STK TaskCheckStk[TASK_CHECK_STK_SIZE]; // 創(chuàng)建任務(wù) - 信號(hào)檢測(cè)OSTaskCreateExt((void (*)(void *)) AppTaskCheck, (void *) 0, (OS_STK *)&TaskCheckStk[TASK_CHECK_STK_SIZE-1],

(INT8U ) TASK_CHECK_PRIO, (INT16U ) TASK_CHECK_PRIO, (OS_STK *)&TaskCheckStk[0], (INT32U ) TASK_CHECK_STK_SIZE, (void *) 0, (INT16U )(OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR)); // 任務(wù)應(yīng)用實(shí)現(xiàn)void AppTaskCheck(void *p_arg){ // 代碼··· (void)p_arg; for(;;) { // 代碼··· }} FreeRRTOS創(chuàng)建一個(gè)任務(wù)類似,也是在創(chuàng)建時(shí)分配堆棧大?。?/p>

#define TASK_CHECK_PRIO 6#define TASK_CHECK_STK_SIZE 128 BaseType_t xReturn; xReturn = xTaskCreate(AppTaskCheck, “AppTaskCheck”, TASK_CHECK_STK_SIZE, NULL, TASK_CHECK_PRIO, NULL); 除了堆棧,其實(shí)還有像消息隊(duì)列、消息郵箱等也是需要提前分配堆棧。 比如FreeRTOS創(chuàng)建CLI消息隊(duì)列:

#define CLI_QUEUE_NUM 256 //CLI接收隊(duì)列數(shù)#define CLI_PACKAGE_LEN 2 //CLI數(shù)據(jù)包長(zhǎng)度 QueueHandle_t xCLIRcvQueue = NULL; /* 創(chuàng)建隊(duì)列 */if(xCLIRcvQueue == NULL){ xCLIRcvQueue = xQueueCreate(CLI_QUEUE_NUM, CLI_PACKAGE_LEN);}

這就是創(chuàng)建任務(wù)(或隊(duì)列)的分配堆棧,至于具體分配多少,與你實(shí)際情況有關(guān),下面章節(jié)我會(huì)描述。

2任務(wù)代碼量

一個(gè)任務(wù)的代碼量,就是你任務(wù)中調(diào)用的那些代碼。 比如上面例子中的代碼:

// 任務(wù)應(yīng)用實(shí)現(xiàn)void AppTaskCheck(void *p_arg){ // 代碼··· (void)p_arg; for(;;) { // 代碼··· }}

這里可能寫了幾千行代碼,或者調(diào)用了上百個(gè)函數(shù),每個(gè)函數(shù)里面都有不少代碼。

這樣下來(lái),這一個(gè)任務(wù)的代碼量就很大了。

3任務(wù)代碼量和堆棧大小有關(guān)系嗎?

很多人就存在一個(gè)疑惑:任務(wù)掛起,要在堆棧中臨時(shí)保存任務(wù),如果這個(gè)任務(wù)的代碼量很大,是不需要很大堆棧空間才行?

答案:不一定需要很大堆棧空間,任務(wù)代碼量和堆棧也沒有直接關(guān)系。

可能很多初學(xué)者存在這么一個(gè)誤區(qū):保存一個(gè)任務(wù),就是把這個(gè)任務(wù)所有代碼都保存起來(lái)(在堆棧中)。

堆棧主要保存是這個(gè)任務(wù)自身的變量(控制塊),還有臨時(shí)變量等這些關(guān)鍵變量信息,而并非要保存所有代碼。

4堆棧分配多大才合適?

任務(wù)堆棧大小,主要取決于你任務(wù)中【臨時(shí)變量】的多少。 注意:臨時(shí)變量包含你代碼中所有嵌套函數(shù)中的臨時(shí)變量。 對(duì)于RAM資源相對(duì)較大的處理器,你可以盡量分配多一點(diǎn)堆棧資源。 但是,很多時(shí)候,我們的RAM資源都是相對(duì)比較緊張的。這個(gè)時(shí)候,就需要你綜合平衡。 比如靜態(tài)局部變量:

void AppTaskCheck(void *p_arg){ static uint8_t aaa; //靜態(tài)局部變量 (void)p_arg; for(;;) { // 代碼··· }} 這里的aaa變量就不會(huì)占用該任務(wù)的堆??臻g,但是它會(huì)占用全局變量(RAM)空間。 用靜態(tài)局部變量,還是臨時(shí)變量,要牽涉到你項(xiàng)目具體情況,比如:RAM資源、代碼運(yùn)行效率等。(臨時(shí)變量還會(huì)有一個(gè)數(shù)據(jù)拷貝過程) 所以,該如何分配堆棧,該用靜態(tài)還是臨時(shí)變量,需要綜合考慮你項(xiàng)目的情況而定。

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19896

    瀏覽量

    235345
  • RAM
    RAM
    +關(guān)注

    關(guān)注

    8

    文章

    1392

    瀏覽量

    117567
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4900

    瀏覽量

    70768

原文標(biāo)題:RTOS任務(wù)的堆棧大小與代碼量有關(guān)嗎?

文章出處:【微信號(hào):strongerHuang,微信公眾號(hào):strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    關(guān)于使用RTOS編程時(shí)藍(lán)牙無(wú)法正常啟動(dòng)的問題求解

    我的電路板是 CYW20829 在編寫基于 RTOS 的 BLE 程序時(shí),我創(chuàng)建了一些其他任務(wù)并運(yùn)行了程序,這導(dǎo)致藍(lán)牙初始化失敗,也就是說(shuō)藍(lán)牙無(wú)法啟動(dòng)。 程序只打印了藍(lán)牙初始化前的內(nèi)容。 [i
    發(fā)表于 07-01 07:15

    【RA4L1-SENSOR】05 按鍵實(shí)現(xiàn)RTOS任務(wù)切換

    ; 配置任務(wù)、隊(duì)列和信號(hào) 開發(fā)板實(shí)體按鍵接在了P000和P001上 在Pins--P0--P000,設(shè)置Symbolic Name為KEY1,模式是輸入模式。P001(KEY2)同理。 現(xiàn)在
    發(fā)表于 06-16 22:38

    詳解RTOS中的Hook函數(shù)

    Hook函數(shù)是RTOS中的一個(gè)關(guān)鍵特性,通過該函數(shù),用戶可以增強(qiáng)對(duì)任務(wù)管理的控制,定義系統(tǒng)行為。
    的頭像 發(fā)表于 03-24 16:14 ?394次閱讀

    RTOS中的本地存儲(chǔ)指針使用

    本地存儲(chǔ)指針是RTOS中的一個(gè)重要特性,增強(qiáng)了任務(wù)管理和數(shù)據(jù)處理能力。在RTOS上下文中,本地存儲(chǔ)是指存儲(chǔ)在本地的特定任務(wù)或?qū)ο蟮臄?shù)據(jù)。通常與任務(wù)
    的頭像 發(fā)表于 02-28 16:33 ?919次閱讀
    <b class='flag-5'>RTOS</b>中的本地存儲(chǔ)指針使用

    使用任務(wù)通知提高RTOS應(yīng)用的效率

    在實(shí)時(shí)嵌入式系統(tǒng)中,性能和資源效率是決定設(shè)計(jì)成敗的關(guān)鍵因素。傳統(tǒng)的實(shí)時(shí)操作系統(tǒng)(RTOS)提供了如隊(duì)列、信號(hào)和事件組機(jī)制,實(shí)現(xiàn)任務(wù)之間的同步和通信。FreeRTOS/SAFERTOS還提供一種方法可以使這些過程更快、更輕量化,
    的頭像 發(fā)表于 12-27 14:54 ?703次閱讀

    RTOS與Linux到底什么區(qū)別

    很多做嵌入式開發(fā)的小伙伴都存在這樣的疑惑:RTOS與Linux到底什么區(qū)別?
    的頭像 發(fā)表于 10-29 09:53 ?1302次閱讀

    C2000?MCU的運(yùn)行時(shí)堆棧大小監(jiān)測(cè)

    電子發(fā)燒友網(wǎng)站提供《C2000?MCU的運(yùn)行時(shí)堆棧大小監(jiān)測(cè).pdf》資料免費(fèi)下載
    發(fā)表于 09-11 09:30 ?0次下載
    C2000?MCU的運(yùn)行時(shí)<b class='flag-5'>堆棧</b><b class='flag-5'>大小</b>監(jiān)測(cè)

    freertos最多支持多少個(gè)任務(wù)

    以下幾個(gè)因素: 系統(tǒng)資源 :FreeRTOS能夠支持的任務(wù)數(shù)量受到系統(tǒng)硬件資源的限制,特別是處理器的RAM大小和性能。RAM用于存儲(chǔ)任務(wù)的控制塊(TCB)和任務(wù)
    的頭像 發(fā)表于 09-02 14:21 ?2277次閱讀

    freertos和rtos區(qū)別是什么

    FreeRTOS 和 RTOS(實(shí)時(shí)操作系統(tǒng))是兩個(gè)不同的概念,但它們之間緊密的聯(lián)系。FreeRTOS 是一個(gè)特定的開源實(shí)時(shí)操作系統(tǒng),而 RTOS 是實(shí)時(shí)操作系統(tǒng)的一般概念。 概念定義 RT
    的頭像 發(fā)表于 09-02 14:18 ?3039次閱讀

    數(shù)字量與模擬關(guān)系如何算

    數(shù)字量與模擬之間的關(guān)系主要體現(xiàn)在它們之間的轉(zhuǎn)換上,這種轉(zhuǎn)換通常通過模數(shù)轉(zhuǎn)換器(ADC)和數(shù)模轉(zhuǎn)換器(DAC)來(lái)實(shí)現(xiàn)。以下是對(duì)兩者關(guān)系的介紹: 一、定義與基本關(guān)系 模擬
    的頭像 發(fā)表于 08-30 09:16 ?1866次閱讀

    堆棧和內(nèi)存的基本知識(shí)

    本文主要聊聊關(guān)于堆棧的內(nèi)容。包括堆棧和內(nèi)存的基本知識(shí)。常見和堆棧相關(guān)的 bug,如棧溢出,內(nèi)存泄漏,堆內(nèi)存分配失敗等。后面介紹軟件中堆棧統(tǒng)計(jì)的重要性,以及如何使用工具工具軟件中
    的頭像 發(fā)表于 08-29 14:10 ?1049次閱讀
    <b class='flag-5'>堆棧</b>和內(nèi)存的基本知識(shí)

    RTOS與Linux什么區(qū)別

    RTOS(Real-Time Operating System,實(shí)時(shí)操作系統(tǒng))與Linux是兩種在不同應(yīng)用場(chǎng)景下發(fā)揮重要作用的操作系統(tǒng),它們?cè)谠O(shè)計(jì)理念、功能特性、應(yīng)用場(chǎng)景以及性能表現(xiàn)等方面存在顯著差異。以下是對(duì)RTOS與Linux區(qū)別的詳細(xì)分析。
    的頭像 發(fā)表于 08-20 16:05 ?6648次閱讀

    RTOS開發(fā)最佳實(shí)踐

    基于RTOS編寫應(yīng)用程序時(shí),一些要注意事項(xiàng)。在本節(jié)中,您將學(xué)習(xí)RTOS開發(fā)最佳實(shí)踐,例如POSIX合規(guī)性、安全性和功能安全認(rèn)證。
    的頭像 發(fā)表于 08-20 11:24 ?853次閱讀

    電容大小與濾波頻率的關(guān)系是什么

    電容大小與濾波頻率的關(guān)系是一個(gè)非常重要的電子學(xué)問題,它涉及到電路設(shè)計(jì)、信號(hào)處理、電源管理等多個(gè)領(lǐng)域。 一、電容的基本特性 定義:電容是一種電子元件,能夠存儲(chǔ)電荷。它的單位是法拉(F),通常用微法
    的頭像 發(fā)表于 07-29 09:13 ?6900次閱讀

    xTaskCreate能否把堆棧上限調(diào)整為2K或者1k?

    RTOS SDK 的系統(tǒng)任務(wù)優(yōu)先級(jí)為 15 ,創(chuàng)建任務(wù)的接?口 xTaskCreate 為 freeRTOS ?自帶接?口,使 ?用 xTaskCreate 創(chuàng)建任務(wù)時(shí),
    發(fā)表于 07-22 06:31