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 ? 來源: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è)檢測(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)檢測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ù)包長度 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ù)里面都有不少代碼。

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

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

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

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

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

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

4堆棧分配多大才合適?

任務(wù)堆棧大小,主要取決于你任務(wù)中【臨時(shí)變量】的多少。 注意:臨時(shí)變量包含你代碼中所有嵌套函數(shù)中的臨時(shí)變量。 對于RAM資源相對較大的處理器,你可以盡量分配多一點(diǎn)堆棧資源。 但是,很多時(shí)候,我們的RAM資源都是相對比較緊張的。這個(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)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    20069

    瀏覽量

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

    關(guān)注

    8

    文章

    1396

    瀏覽量

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

    關(guān)注

    30

    文章

    4922

    瀏覽量

    72220

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    這兩種TVS不同?

    當(dāng)我們查看TVS二極管的規(guī)格書,常會(huì)看到以下兩種種引腳功能標(biāo)識(shí)圖:對于初學(xué)者,看到感到疑惑,他們一樣嗎?他們區(qū)別?為啥有的兩個(gè)尖頭往外,陽極連在一起,有的兩個(gè)尖頭往里,陰極連在一起?一連三問。EMC小哥根據(jù)自己經(jīng)驗(yàn)略作分析
    的頭像 發(fā)表于 09-15 20:27 ?377次閱讀
    這兩種TVS<b class='flag-5'>有</b><b class='flag-5'>啥</b>不同?

    可配置的數(shù)據(jù)閃存大小、地址和 APROM 之間什么關(guān)系?

    可配置的數(shù)據(jù)閃存大小、地址和 APROM 之間什么關(guān)系?
    發(fā)表于 08-26 06:58

    請問可配置的數(shù)據(jù)閃存大小、地址和 APROM 之間什么關(guān)系?

    可配置的數(shù)據(jù)閃存大小、地址和 APROM 之間什么關(guān)系
    發(fā)表于 08-21 07:10

    電磁干擾“江湖三兄弟”:EMC、EMI、EMS 到底區(qū)別?

    電磁干擾“江湖三兄弟”:EMC、EMI、EMS 到底區(qū)別?
    的頭像 發(fā)表于 08-20 15:16 ?1400次閱讀
    電磁干擾“江湖三兄弟”:EMC、EMI、EMS 到底<b class='flag-5'>有</b><b class='flag-5'>啥</b>區(qū)別?

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

    我的電路板是 CYW20829 在編寫基于 RTOS 的 BLE 程序時(shí),我創(chuàng)建了一些其他任務(wù)并運(yùn)行了程序,這導(dǎo)致藍(lán)牙初始化失敗,也就是說藍(lán)牙無法啟動(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

    切割進(jìn)給與碳化硅襯底厚度均勻性的量化關(guān)系及工藝優(yōu)化

    引言 在碳化硅襯底加工過程中,切割進(jìn)給是影響其厚度均勻性的關(guān)鍵工藝參數(shù)。深入探究二者的量化關(guān)系,并進(jìn)行工藝優(yōu)化,對提升碳化硅襯底質(zhì)量、滿足半導(dǎo)體器件制造需求具有重要意義。 量化關(guān)系分析 切割機(jī)
    的頭像 發(fā)表于 06-12 10:03 ?401次閱讀
    切割進(jìn)給<b class='flag-5'>量</b>與碳化硅襯底厚度均勻性的量化<b class='flag-5'>關(guān)系</b>及工藝優(yōu)化

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

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

    嵌入式開發(fā)避坑指南|FreeRTOS的5個(gè)\"反直覺\"小技巧

    同步分配堆棧內(nèi)存 關(guān)鍵代碼段用portENTER_CRITICAL()保護(hù),防止中斷搶占 案例:某工業(yè)控制系統(tǒng)因GPS任務(wù)搶占溫濕度任務(wù),導(dǎo)致數(shù)據(jù)丟失 技巧3:信號(hào)
    發(fā)表于 03-20 13:57

    租用服務(wù)器帶寬預(yù)估大小怎么算?

    在租用服務(wù)器時(shí),準(zhǔn)確預(yù)估所需的帶寬大小是確保網(wǎng)站或應(yīng)用穩(wěn)定運(yùn)行的關(guān)鍵。帶寬作為數(shù)據(jù)傳輸速率的指標(biāo),直接關(guān)系到用戶訪問體驗(yàn)和服務(wù)質(zhì)量。租用服務(wù)器帶寬預(yù)估大小怎么算需要考慮多方面因素,包括網(wǎng)站類型、用戶
    的頭像 發(fā)表于 03-17 16:45 ?501次閱讀

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

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

    ADS1294和ADS1298區(qū)別啊?

    您好,請教一下您這個(gè)ADS1294和ADS1298區(qū)別?。窟€有帶R的和不帶R的區(qū)別?。课铱从玫亩际且粋€(gè)手冊。順便再問一下您,ADS1291和ADS1292
    發(fā)表于 12-25 06:31

    一種實(shí)現(xiàn)亞毫秒定時(shí)分辨率的RTOS新方法

    你在使用實(shí)時(shí)操作系統(tǒng)(RTOS)時(shí)是否發(fā)現(xiàn)無法將任務(wù)調(diào)度或延遲精度降到毫秒以下?你可能不得不在RTOS之外編寫大量應(yīng)用代碼。雖然這種方式可行,但這會(huì)讓你懷疑應(yīng)用程序是否滿足其截止期限,
    的頭像 發(fā)表于 12-17 13:58 ?639次閱讀
    一種實(shí)現(xiàn)亞毫秒定時(shí)分辨率的<b class='flag-5'>RTOS</b>新方法

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

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