keil调试变量值被篡改问题
今天遇到一个代码中变量值被篡改的问题,某个数组的第一个值运行一段时间之后变成了0,如图:
看现象基本可以断定是内存越界导致的,但是要如果定位是哪里内存越界呢?
keil提供了两个工具
1、set access breakpoint at(设置访问断点)
2、call stack(查看调用栈)
通过设置访问断点,可以在变量受到篡改时命中断点,命中后就可以通过调用栈call stack来查看调用关系,一步确定篡改者;
keil的call stack工具的功能和gdb 的 bt full一样,可以将调用关系一层层展示出来