就我们最新下载的,TencentOS v2.4.x版本,任务间通讯用的队列,分得比较细:
1_> 消息队列: 提供了任务间传递指针数据的机制,所谓的“消息“就是指针
2_> 邮箱队列: 消息队列传递的是指针,邮箱队列传递的是大片的内存数据
3_> 优先级消息队列: 加入优先级概念
4_> 优先级邮箱队列: 加入优先级概念
它们操作大同小异,我们就以官方TencentOS-tiny\doc的04.Development_Manual例,
找到消息队列例子,并新建我们的文件于TencentOS-tiny\board\SWM320_DISCOVERY\BSP\Src内
新建文件tOS_msg_q.c为:
/* 这里演示如何使用消息队列在sender和receiver任务之间传递消息(一个指针,此案例中这个指针信息指向的是一个字符串) */ #include "tos_k.h" #include "mcu_init.h" #define STK_SIZE_TASK_RECEIVER 512 #define STK_SIZE_TASK_SENDER 512 #define PRIO_TASK_RECEIVER_HIGHER_PRIO 4 #define PRIO_TASK_RECEIVER_LOWER_PRIO (PRIO_TASK_RECEIVER_HIGHER_PRIO + 1) #define MESSAGE_MAX 10 k_stack_t stack_task_receiver_higher_prio[STK_SIZE_TASK_RECEIVER]; k_stack_t stack_task_receiver_lower_prio[STK_SIZE_TASK_RECEIVER]; k_stack_t stack_task_sender[STK_SIZE_TASK_SENDER]; uint8_t msg_pool[MESSAGE_MAX * sizeof(void *)]; k_task_t task_receiver_higher_prio; k_task_t task_receiver_lower_prio; k_task_t task_sender; k_msg_q_t msg_q; extern void entry_task_receiver_higher_prio(void *arg); extern void entry_task_receiver_lower_prio(void *arg); extern void entry_task_sender(void *arg); void entry_task_receiver_higher_prio(void *arg) { k_err_t err; void *msg_received; while (K_TRUE) { err = tos_msg_q_pend(&msg_q, &msg_received, TOS_TIME_FOREVER); if (err == K_ERR_NONE) { printf("higher: msg incoming[%s]\n", (char *)msg_received); } } } void entry_task_receiver_lower_prio(void *arg) { k_err_t err; void *msg_received; while (K_TRUE) { err = tos_msg_q_pend(&msg_q, &msg_received, TOS_TIME_FOREVER); if (err == K_ERR_NONE) { printf("lower: msg incoming[%s]\n", (char *)msg_received); } } } void entry_task_sender(void *arg) { int i = 1; char *msg_to_one_receiver = "message for one receiver(with highest priority)"; char *msg_to_all_receiver = "message for all receivers"; while (K_TRUE) { if (i == 2) { printf("sender: send a message to one receiver, and shoud be the highest priority one\n"); tos_msg_q_post(&msg_q, msg_to_one_receiver); } if (i == 3) { printf("sender: send a message to all recevier\n"); tos_msg_q_post_all(&msg_q, msg_to_all_receiver); } if (i == 4) { printf("sender: send a message to one receiver, and shoud be the highest priority one\n"); tos_msg_q_post(&msg_q, msg_to_one_receiver); } if (i == 5) { printf("sender: send a message to all recevier\n"); tos_msg_q_post_all(&msg_q, msg_to_all_receiver); } tos_task_delay(1000); ++i; } } /*-------------------------测试的应用函数入口--------------------------------*/ void application_msg_q(void *arg) // msg_q消息队列测试 { tos_msg_q_create(&msg_q, msg_pool, MESSAGE_MAX); tos_task_create(&task_receiver_higher_prio, "receiver_higher_prio", entry_task_receiver_higher_prio, NULL, PRIO_TASK_RECEIVER_HIGHER_PRIO, stack_task_receiver_higher_prio, STK_SIZE_TASK_RECEIVER, 0); tos_task_create(&task_receiver_lower_prio, "receiver_lower_prio", entry_task_receiver_lower_prio, NULL, PRIO_TASK_RECEIVER_LOWER_PRIO, stack_task_receiver_lower_prio, STK_SIZE_TASK_RECEIVER, 0); tos_task_create(&task_sender, "sender", entry_task_sender, NULL, 4, stack_task_sender, STK_SIZE_TASK_SENDER, 0); }
测试成功,这里的测试只是传个字符串指针,能传指针就非常方便了,不限于字符串。。。是不是??