完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
使用RT-Thread的过程中发现常常进assert,发现是在某个线程调用mutex时挂死的,所以想在rt_thread_self里检测是从哪个线程进来的。 但打印出来有的时候是空值,why? 除了可以通过看thread->name,还有办法可以达到看当前是在哪个线程的目的吗? void rt_assert_handler(const char *ex_string, const char *func, rt_size_t line) { volatile char dummy = 0; if (rt_assert_hook == RT_NULL) { #ifdef RT_USING_MODULE if (dlmodule_self()) { /* close assertion module */ dlmodule_exit(-1); } else #endif /*RT_USING_MODULE*/ { rt_thread_t cur_thread = rt_thread_self(); rt_kprintf("assertion thread: %s\n", cur_thread->name); // rt_kprintf("(%s) assertion failed at function:%s, line number:%d \n", // ex_string, func, line); while (dummy == 0) ; } } else { rt_assert_hook(ex_string, func, line); } } 打印输出:
|
|
相关推荐
1个回答
|
|
你可以试试把当前线程都打出来,类似命令ps一下。看看哪个线程当前在跑。
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
764 浏览 0 评论
3847 浏览 0 评论
如何使用python调起UDE STK5.2进行下载自动化下载呢?
2479 浏览 0 评论
开启全新AI时代 智能嵌入式系统快速发展——“第六届国产嵌入式操作系统技术与产业发展论坛”圆满结束
2901 浏览 0 评论
获奖公布!2024 RT-Thread全球巡回线下培训火热来袭!报名提问有奖!
31185 浏览 11 评论
72809 浏览 21 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-20 07:44 , Processed in 0.399368 second(s), Total 39, Slave 32 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号