Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
线程上下文调度切换_context
创建两个线程打印信息,结果和想象的不太一样
发布于 2024-04-11 11:33:48 浏览:473
订阅该版
程序如下 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240411/f4d11d5a95b4dd046bdd168bff26cab5.png) 打印结果如下 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240411/b2d1f7017cdbb893d1e559d47939bc28.png) 为什么在打印 “tid2” 的时候, 会出现“tidid2”这种情况。感觉应该打印“id1\t\t”,因为前面有一个打印了“ttid2”,很明显是线程1执行到打印“t”的时候切换到了线程2 4.11 感谢大家的回复。增加了延时之后确实是没有乱码了,但是依然没搞懂这个乱码的原理。 按照理论来说,线程1先启动,所以它先打印了。 当应该打印第三个“tid1”时,由于时间片用完了,这时候只打印了**“t”**。 要切换线程,所以会保存线程1上下文,内容应该是当前打印到哪了. ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240411/7fa4881c2257512080211209ad0326c7.png) 这时候线程2开始启动,打印“tid2” 当应该打印第四个“tid2”时,**貌似**是时间片用完了,这时候只打印了“tid”。 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240411/3a4aa25f4d57fcf2dec717e6ae9c7561.png) 照理说应该给切换到线程1了,然后把线程1的上下文内容取出,并接着打印**“id1\t\t”**, 但实际结果却是打印了**“id2\t\t”** ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240411/8a8a008989bd74963959a4140e3be2ce.png) 所以我想知道,为什么会出现这种情况,是和打印这个函数的特性有关么。另外我发现官方出版的《RTT编程指南》给的例程也存在这样的问题,如下图所示: ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240411/dca08803e323d72ad2dbb749601b9a11.png.webp) 第一次切换线程,停在了**“thread 1 is r”** 照理说下次再切换回线程1时,应该打印**“unning ,thread 1 count = 130”** 单词是接上了,说明上下文肯定起作用了,但是数值却和想象的不一样😓, 感觉切换线程的时候,CPU在反复横跳,求大佬解释,感谢!!!
查看更多
6
个回答
默认排序
按发布时间排序
JonasWen
2024-04-11
这家伙不懒,但是什么也不想写!
rt_kprintf是线程不安全的,打印的时候是把内容写到静态局部变量`static char rt_log_buf[RT_CONSOLEBUF_SIZE];`里的,时间片轮转导致里面的数据被污染了,所以打印出来的数据不是你想象的那样
踩姑娘的小蘑菇
2024-04-11
这家伙很懒,什么也没写!
因为是同优先级线程,生效的是时间片轮询调度,时间片用尽会切换到同优先级线程运行
小小李sunny
2024-04-11
这家伙很懒,什么也没写!
线程里加个延时,不要一直占用
huoshen
2024-04-11
这家伙很懒,什么也没写!
延时一下
梦笑真美
2024-04-12
这家伙很懒,什么也没写!
加个延时,时间错开多点儿
用户名由3_15位
2024-04-12
这家伙很懒,什么也没写!
- printf添加互斥或中断屏蔽,保证printf打印不会被中断; - 或者单独开个线程专门用于输出日志
撰写答案
登录
注册新账号
关注者
0
被浏览
473
关于作者
rosli
这家伙很懒,什么也没写!
提问
2
回答
1
被采纳
0
关注TA
发私信
相关问题
1
modbusRTU如何避免因为被高优先级任务切走而导致本次通讯失败
2
RT-Thread 4.0.2初次上下文切换失败
3
pendSV中bx lr指令,lr指向哪里?psp中剩余的寄存器啥时候弹出的?
4
Cortex-M0在bootloader环境下的上下文切换问题?
5
arc内核移植线程切换
6
rt_thread_yield 无法在同级别中释放cpu
7
线程执行完后退出 是如何通知cpu切换任务的
8
RTT-NANO 3.1.3 线程切换问题
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
RT-Thread项目助手v0.2.0 - 支持Env Windows
2
RttreadV5.10上,GD32F450Z RTC时间显示问题
3
rt-smart启动流程分析
4
EtherKit快速上手PROFINET
5
RTThread USB转串口无法接收数据
热门标签
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
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部