今天在写一个应用程序,在开发板上测试的时候,发生了段错误
让程序在开发板上直接运行,当它发生错误时,令它产生core dump文件
然后使用gdb根据core dump文件找到发生错误的地方
在ARM板上:
- ulimit -c unlimited
- 执行应用程序 : 程序出错时会在当前目录下生成名为core的文件
在PC上:
3. /bin/arm-linux-gdb ./test_debug ./core
用gdb调试
之后再虚拟机上执行
gdb模式下输入 bt 可以打印出发生段错误出的堆栈信息,可以找到错误位置
发现在这里发生了错误
找到代码位置snprintf处
其中这个函数的参数tFileMap.strFileName出错
tFileMap 这个结构体的定义如下
结构体成员strFileName,不应该定义为指针,应该分配一个空间该strFileName
所以修改如下
问题解决
使用backstrace命令也可以定位错误发生处