完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
线程运行ASSERT()失败。进入RTT中缺省的ASSERT()函数体中。 如果是有main()函数中,出现这个现象,调试时容易被发现。 如果创建了多个线程,出现这个现象,会误解为线程挂起。 |
|
相关推荐
4个回答
|
|
assert 之后整个系统宕机,还考虑打印信息?
|
|
|
|
系统并没有宕机,而是在ASSERT()中的一个while(1)语句中,无限循环,改造这个assert语句。
kservice.c 文件中 rt_assert_handler(), 通常停留在 while (dummy == 0); 把rt_kprintf()函数重新指向到一个串口或者console输出即可。原始函数是一个空函数。 /** The RT_ASSERT function. * @param ex the assertion condition string @param func the function name when assertion. @param line the file line number when assertion. / 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_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); } } RTM_EXPORT(rt_assert_handler); endif / RT_DEBUG / |
|
|
|
如果觉得还能跑那别用ASSERT()判断
如果是为了提醒那用条件语句判断然后输出日志信息 assert的while(1)是为了防止系统跑飞,错误的地方停下来你还能找找问题。 如果是为了排查错误,这里推荐使用组件CmBacktrace来定位引起assert失败的函数调用关系 |
|
|
|
学习了。努力提高bug定位水平。
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
788 浏览 0 评论
4271 浏览 0 评论
如何使用python调起UDE STK5.2进行下载自动化下载呢?
2529 浏览 0 评论
开启全新AI时代 智能嵌入式系统快速发展——“第六届国产嵌入式操作系统技术与产业发展论坛”圆满结束
2929 浏览 0 评论
获奖公布!2024 RT-Thread全球巡回线下培训火热来袭!报名提问有奖!
31479 浏览 11 评论
72925 浏览 21 评论
浏览过的版块 |
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-22 18:31 , Processed in 0.595368 second(s), Total 78, Slave 61 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号