Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
MicroPython
多线程死机问题(与gc有关)
发布于 2018-12-28 10:20:46 浏览:2438
订阅该版
* 本帖最后由 hxcnz 于 2018-12-28 10:38 编辑 * RT-Thread MicroPython 堆设了40k左右,单While循环长时间运行都正常,把 _thread 模块加入之后,运行几十秒就死机了(这时候比MicroPython优先级高的进程还能正常运行,说明RT-Thread系统没有死机),代码如下:```import time import _thread import gc def Test(): while True: time.sleep_ms(10) _thread.start_new_thread(Test, ()) cnt = 0 a0 = 10.5 a1 = 1.1 a2 = 2.2 a3 = 3.3 a4 = 4.4 a5 = 5.5 a6 = 6.6 a7 = 7.6 while True: cnt += 1 a0 += 1 a1 += 1 a2 += 1 a3 += 1 a4 += 1 a5 += 1 a6 += 1 a7 += 1 print("While cnt:",cnt) print( "%f" % (a0), "%f" % (a1), "%f" % (a2), "%f" % (a3), "%f" % (a4), "%f" % (a5), "%f" % (a6), "%f" % (a7), ) time.sleep_ms(100)```输出结果为: \ | / - RT - Thread Operating System / | \ 4.0.0 build Dec 28 2018 2006 - 2018 Copyright by rt-thread team msh />ROM file system initializated! TF_Card initialized! msh />While cnt: 1 11.500000 2.100000 3.200000 4.300000 5.400000 6.500000 7.600000 8.600000 While cnt: 2 12.500000 3.100000 4.200000 5.300000 6.400000 7.500000 8.600000 9.600000 While cnt: 3 13.500000 4.100000 5.200000 6.300000 7.400000 8.500000 9.600000 10.600000 ***此处省略n行*** While cnt: 150 160.500000 151.100000 152.200000 153.300000 154.400000 155.500000 156.600000 157.600000 While cnt: 151 161.500000 152.100000 153.200000 154.300000 155.400000 156.500000 157.600000 158.600000 While cnt: 152 在这里就卡死了,后来用 gc.mem_free() 查看剩余内存: ```import time import _thread import gc def mem(): r = gc.mem_free() print("free memory:", r) def Test(): while True: time.sleep_ms(10) _thread.start_new_thread(Test, ()) cnt = 0 a0 = 10.5 a1 = 1.1 a2 = 2.2 a3 = 3.3 a4 = 4.4 a5 = 5.5 a6 = 6.6 a7 = 7.6 while True: cnt += 1 a0 += 1 a1 += 1 a2 += 1 a3 += 1 a4 += 1 a5 += 1 a6 += 1 a7 += 1 print("While cnt:",cnt) print( "%f" % (a0), "%f" % (a1), "%f" % (a2), "%f" % (a3), "%f" % (a4), "%f" % (a5), "%f" % (a6), "%f" % (a7), ) mem() time.sleep_ms(100)```输出结果如下: ***上面省略n行*** free memory: 1632 While cnt: 151 161.500000 152.100000 153.200000 154.300000 155.400000 156.500000 157.600000 158.600000 free memory: 1200 While cnt: 152 162.500000 153.100000 154.200000 155.300000 156.400000 157.500000 158.600000 159.600000 free memory: 768 While cnt: 153 163.500000 154.100000 155.200000 156.300000 157.400000 158.500000 159.600000 160.600000 free memory: 336 While cnt: 154 可看出剩余内存剩余不多了,这时候Python系统应该是自动执行gc.collect()的时候死机了,分析完整打印数据看出,在死机之前,已经经历了2~3次gc.collect()了。 注:在单线程运行的时候,free memory 在400的时候会执行一次gc,大概20s执行一次,连续运行7、8个小时都不会出问题。 接着增加手动gc试下: ```import time import _thread import gc def mem(): r = gc.mem_free() print("free memory:", r) def Test(): while True: time.sleep_ms(10) _thread.start_new_thread(Test, ()) cnt = 0 a0 = 10.5 a1 = 1.1 a2 = 2.2 a3 = 3.3 a4 = 4.4 a5 = 5.5 a6 = 6.6 a7 = 7.6 while True: cnt += 1 a0 += 1 a1 += 1 a2 += 1 a3 += 1 a4 += 1 a5 += 1 a6 += 1 a7 += 1 print("While cnt:",cnt) print( "%f" % (a0), "%f" % (a1), "%f" % (a2), "%f" % (a3), "%f" % (a4), "%f" % (a5), "%f" % (a6), "%f" % (a7), ) gc.collect() mem() time.sleep_ms(100)```输出结果如下: \ | / - RT - Thread Operating System / | \ 4.0.0 build Dec 28 2018 2006 - 2018 Copyright by rt-thread team msh />ROM file system initializated! TF_Card initialized! msh />While cnt: 1 11.500000 2.100000 3.200000 4.300000 5.400000 6.500000 7.600000 8.600000 free memory: 33024 While cnt: 2 12.500000 3.100000 4.200000 5.300000 6.400000 7.500000 8.600000 9.600000 在这里就卡死了,手动gc活不过3集{:3_45:},求大神分析下什么原因,要怎样才能解决问题?难不成多线程用不了么? 后来将 gc.collect()改为: if gc.mem_free() < 10000: gc.collect() 在执行2次gc.collect()后,还是死机了,感觉有多线程的情况下,不管手动gc还是自动gc,gc.collect()第三次就会死机。
查看更多
6
个回答
默认排序
按发布时间排序
armink
2018-12-28
这家伙很懒,什么也没写!
多线程用着好像是有些坑,不太确认是否与你这个有关呢。其他时候 使用 GC 都挺好的吧
hxcnz
2018-12-28
这家伙很懒,什么也没写!
>多线程用着好像是有些坑,不太确认是否与你这个有关呢。其他时候 使用 GC 都挺好的吧 ... --- 只有一个while循环的时候,从来没出问题,也从来没关心过gc,都是系统自动回收的,然后加了一个线程进去后,用着用着就挂了
armink
2018-12-28
这家伙很懒,什么也没写!
>只有一个while循环的时候,从来没出问题,也从来没关心过gc,都是系统自动回收的,然后加了一个线程进去 ... --- 这估计得深入分析下 GC 流程了,没准把不该回收的地方 GC 了
hxcnz
2018-12-28
这家伙很懒,什么也没写!
>这估计得深入分析下 GC 流程了,没准把不该回收的地方 GC 了 --- {:3_45:}有可能。。
armink
2019-01-12
这家伙很懒,什么也没写!
你好,近期对多线程及 gc 问题做了些修正,你的代码现在 RT-Thread 的 MicroPython 上运行没问题了。 感谢你的反馈,欢迎测试哈。 [attach]7209[/attach]
hxcnz
2019-01-14
这家伙很懒,什么也没写!
>你好,近期对多线程及 gc 问题做了些修正,你的代码现在 RT-Thread 的 MicroPython 上运行没问题了。 > >感谢 ... --- 好,我测下看!
撰写答案
登录
注册新账号
关注者
0
被浏览
2.4k
关于作者
hxcnz
这家伙很懒,什么也没写!
提问
10
回答
37
被采纳
0
关注TA
发私信
相关问题
1
请问rt-thread有没有移植micropython呢
2
micropython import 文件名的方式执行脚本问题
3
第一篇:Micropython 的起源和发展
4
第二篇:RT-Thread Micropython 简介
5
第三篇:RT-Thread Micropython 快速入门
6
第四篇:Micropython DIY 项目汇总
7
第五篇:Micropython 教程和资源
8
第六篇: RT-Thread MicroPython 学习经验和学习路线
9
RT-Thread MicroPython 最新开发板固件汇总【已失效】
10
有Mpy专门的板块啦~
推荐文章
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
GD32F450 片内 flash驱动适配
2
STM32H7R7运行CherryUSB
3
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
4
使用RC522软件包驱动FM1722
5
常量数据类型和表达式陷阱分享
热门标签
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在线升级
freemodbus
PWM
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
5
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部