定长内存管理方案
文章目錄
- 1 定長內(nèi)存管理方案
- 1.1 簡介
- 1.2 示例代碼
1 定長內(nèi)存管理方案
1.1 簡介
適合場合:
應(yīng)用場合:
1.2 示例代碼
如下:
/*** @brief tOS應(yīng)用示例* @details* @author 01課堂 李述銅 http://01ketang.cc* @date 2017-06-01* @version 1.0* @copyright 版權(quán)所有,禁止用于商業(yè)用途*/ #include "tinyOS.h" #include "app.h" #include "hal.h"static tTask task1; // 任務(wù)1結(jié)構(gòu) static tTask task2; // 任務(wù)2結(jié)構(gòu) static tTask task3; // 任務(wù)3結(jié)構(gòu) static tTask task4; // 任務(wù)4結(jié)構(gòu)static tTaskStack task1Env[TASK1_ENV_SIZE]; // 任務(wù)1的堆??臻g static tTaskStack task2Env[TASK2_ENV_SIZE]; // 任務(wù)2的堆??臻g static tTaskStack task3Env[TASK3_ENV_SIZE]; // 任務(wù)3的堆??臻g static tTaskStack task4Env[TASK4_ENV_SIZE]; // 任務(wù)4的堆??臻gint task1Flag; // 用于指示任務(wù)運(yùn)行狀態(tài)的標(biāo)志變量 int task2Flag; // 用于指示任務(wù)運(yùn)行狀態(tài)的標(biāo)志變量 int task3Flag; // 用于指示任務(wù)運(yùn)行狀態(tài)的標(biāo)志變量 int task4Flag; // 用于指示任務(wù)運(yùn)行狀態(tài)的標(biāo)志變量typedef struct __Packet {uint32_t size;uint8_t buffer[100]; } Packet;Packet packetItems[20]; tMemBlock packetMemBlock;void *packetBuffer[20]; tMbox packetMbox;/*** 任務(wù)的運(yùn)行代碼* @param param 任務(wù)初始運(yùn)行參數(shù)*/ void task1Entry (void *param) {Packet *packet;int i = 0;for (;;) {tMemBlockWait(&packetMemBlock, (void **) &packet, 0);packet->size = i++;tMboxNotify(&packetMbox, packet, tMBOXSendNormal);tTaskDelay(1);} }/*** 任務(wù)的運(yùn)行代碼* @param param 任務(wù)初始運(yùn)行參數(shù)*/ void task2Entry (void *param) {Packet *packet;for (;;) {tMboxWait(&packetMbox, (void **) &packet, 0);xprintf("packet size:%d\n", packet->size);tMemBlockNotify(&packetMemBlock, packet);} }/*** 任務(wù)的運(yùn)行代碼* @param param 任務(wù)初始運(yùn)行參數(shù)*/ void task3Entry (void *param) {for (;;) {task3Flag = 1;tTaskDelay(1);task3Flag = 0;tTaskDelay(1);} }/*** 任務(wù)的運(yùn)行代碼* @param param 任務(wù)初始運(yùn)行參數(shù)*/ void task4Entry (void *param) {for (;;) {task4Flag = 1;tTaskDelay(1);task4Flag = 0;tTaskDelay(1);} }/*** App的初始化*/ void tInitApp (void) {halInit();tMboxInit(&packetMbox, packetBuffer, 20);tMemBlockInit(&packetMemBlock, packetItems, sizeof(Packet), 20);tTaskInit(&task1, task1Entry, (void *) 0x0, TASK1_PRIO, task1Env, sizeof(task1Env));tTaskInit(&task2, task2Entry, (void *) 0x0, TASK2_PRIO, task2Env, sizeof(task2Env));tTaskInit(&task3, task3Entry, (void *) 0x0, TASK3_PRIO, task3Env, sizeof(task3Env));tTaskInit(&task4, task4Entry, (void *) 0x0, TASK4_PRIO, task4Env, sizeof(task4Env)); }參考資料:
總結(jié)
- 上一篇: 在VS中建立一个易于管理的C++工程
- 下一篇: 将长度为n的绳子分为m段求各段乘积的最大