OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 1944|回复: 1

记一次变量被莫名其妙的改变的调试记录

[复制链接]

22

主题

49

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
214
金钱
214
注册时间
2014-4-30
在线时间
26 小时
发表于 2019-8-16 12:43:34 | 显示全部楼层 |阅读模式
这两天在做一个wifi控制开关的项目,用的是stm32f070,主要功能串口、wifi模块(esp8266)、rtc、LED、按键(只有一个,手动/自动切换)、继电器。

昨天下午把最后一个功能模块写完之后,发现原来调试正常的wifi模块突然不能联网了,调试了一晚上加今天一上午,用了很多调试办法,都没有结果,一个int型的变量应该要在定时器里加到8000才执行某个操作,但是往往加到700~1000左右的时候就会出现异常。

后来才发现timer3中断中用了一个函数中sprintf函数,
sprintf((char*)str,"%02d%02d%02d%02d%02d%02d",time.Year,time.Month,time.Date,time.Hour,time.Min,time.Sec);


猜测这个函数占用的时间比较久,导致内存不正常。看来像sprintf这种函数最好还是在主循环中使用,避免在中断中使用。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

231

帖子

0

精华

高级会员

Rank: 4

积分
755
金钱
755
注册时间
2018-12-7
在线时间
131 小时
发表于 2019-8-16 13:25:34 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-8 19:13

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表