Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
线程
为什么我只写了循环20次,但是线程一直执行?
发布于 2021-11-04 08:19:42 浏览:1205
订阅该版
th1 线程为什么会永远执行下去不停呢? 第35行我只之让它循环了20次 补上46-48行才让它运行一段时间后停下来 ```c /* * Copyright (c) 2006-2021, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2021-08-24 RT-Thread first version */ #include
#define DBG_TAG "main" #define DBG_LVL DBG_LOG #define MB1_SIZE_MAX 10 #include
rt_thread_t th1 , th2; rt_mq_t mymsq = NULL; rt_mailbox_t mb1 = NULL; typedef struct { uint16_t buf; rt_mailbox_t mb_t; }MYMSG; void th1_entry(void *parameter) { uint16_t mbrx = 0; MYMSG myMsg = {10, mb1}; rt_thread_mdelay(5000); rt_kprintf("\nTx: %d\n", myMsg.buf); rt_mq_send(mymsq, (void*)&myMsg, sizeof(MYMSG)); for (int i=0;i<20;i++){ if (rt_mb_recv(mb1, (rt_ubase_t *)&mbrx, 1500) != RT_EOK){ mbrx = 0; rt_kprintf("Tx: %d ack: %d resending...\n", myMsg.buf, mbrx); } if (mbrx > 0) { if (mbrx == 1) { myMsg.buf++; } else if (mbrx == 2) { myMsg.buf += 2; } // if (myMsg.buf > 35){ // break; // } rt_kprintf("Tx: %d ack: %d sending next msg...\n", myMsg.buf, mbrx); rt_mq_send(mymsq, (void*)&myMsg, sizeof(MYMSG)); } } } void th2_entry(void *parameter) { MYMSG myMsg; for(;;){ rt_thread_mdelay(50); rt_mq_recv(mymsq, (void*)&myMsg, sizeof(MYMSG), RT_WAITING_FOREVER); if ((myMsg.buf % 3) == 0){ rt_mb_send(myMsg.mb_t, 1); rt_kprintf("\nRx: %d ack: 1\n",myMsg.buf); } else { rt_mb_send(myMsg.mb_t, 2); rt_kprintf("\nRx: %d ack: 2\n",myMsg.buf); } } } int main(void) { mymsq = rt_mq_create("mq1", 10, sizeof(MYMSG), RT_IPC_FLAG_FIFO); mb1 = rt_mb_create("mb1", MB1_SIZE_MAX, RT_IPC_FLAG_FIFO); th1 = rt_thread_create("th1", th1_entry,RT_NULL,512, 21, 0); if(th1 == RT_NULL){ LOG_E("th1 rt_thread_create failed...\n"); return -ENOMEM; } th2 = rt_thread_create("th2", th2_entry,RT_NULL,512, 20, 81); if(th1 == RT_NULL){ LOG_E("th2 rt_thread_create failed...\n"); return -ENOMEM; } rt_thread_startup(th1); rt_thread_startup(th2); return 0; } ``` 问题补充。 1. th1线程去掉rt_mb_recv()就好了 2. rtt studio新建的rtt项目会出现这种情况,而使用正点潘多拉提供的demo模板就不会
查看更多
出出啊
2021-11-04
恃人不如自恃,人之为己者不如己之自为也
1. 512 堆栈很紧张 2. `th1 = rt_thread_create("th1", th1_entry,RT_NULL,512, 21, 0);` 0 时间片。这个操作很秀啊。 3. 典型的内存被污染了。导致程序运行不正常。目测这里没有非法写的代码。项目中其它地方可能有bug 4. 刚发现,`rt_mq_create("mq1", 10, sizeof(MYMSG), RT_IPC_FLAG_FIFO);` 这个用法是错的!!! 第二个参数是消息体大小,第二个参数是消息队列中最大消息数量。
3
个回答
默认排序
按发布时间排序
小小李sunny
2021-11-04
这家伙很懒,什么也没写!
调试一下看看,这里for循环中的i的值有变化没
RTT_逍遥
认证专家
2021-11-04
https://github.com/supperthomas
可能th1的线程的任务栈有些小了,试试看把512加大看看。 ``` th1 = rt_thread_create("th1", th1_entry,RT_NULL,512, 21, 0); ```
撰写答案
登录
注册新账号
关注者
0
被浏览
1.2k
关于作者
cypressxt
这家伙很懒,什么也没写!
提问
1
回答
0
被采纳
0
关注TA
发私信
相关问题
1
请问执行rt_thread_delete的操作后,线程还在运行是什么情况?
2
rtthread中,线程中的ADC采样率需求比时钟嘀嗒需求高怎么办?
3
有没有检测系统中有没有某个名字的线程的接口函数?
4
使用finsh 进行ota成功,线程里开ota失败
5
调度锁会引起线程内存不足
6
线程处于close状态消耗资源吗
7
paho_mqtt线程相关疑问
8
thread中不能使用rt_timer_start() 来开启定时器
9
线程递归是什么形成的?
10
程序运行一会儿报错,拜托拜托
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
HC32F4A0 SD卡挂载及热插拔的实现
2
vscode插件 - RT-Thread Studio项目助手 | 跨平台开发
3
Console串口使用说明
4
WATCHDOG设备驱动开发
5
【NXP-MCXA153】eFlexPWM驱动移植
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
编译报错
Debug
rt_mq_消息队列_msg_queue
SFUD
keil_MDK
msh
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
812
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
2
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部