平台:OKMX6Q-S2平台 环境:Linux
一、cmd程序 1、编写一个简单地崩溃程序dest.c,如下: #include "stdio.h" int main() { int *p=NULL; *p=1; //给指针赋值 return 1; } 2、编译 arm-fsl-linux-gnueabi-gcc -g -o 11 dest.c 注意:一定要在命令中加上-g参数,这样使用gdb调试时才能看到具体是程序的哪一行出了错误。 3、将可执行文件11拷贝到开发板,运行程序 root@freescale
/$ulimit -c unlimited 该命令的作用就是生成core文件,就是程序存在段错误时运行产生的文件 root@freescale /$ ./11 Segmentation fault (core dumped) 这时在根目录下已经产生了core文件 4、将产生的core文件与之前的11文件放在电脑上的同一目录下,在命令行使用gdb进行源码级调试
如图可以看到第5行指针赋值出错已经列出。
二、Qt程序 1、Qt程序的调试过程与命令行大同小异,首先编写崩溃程序如下
void MainWindow::on_checkBox_toggled(bool) { int *p=NULL; *p=1; } 当勾选CheckBox的时候,程序崩溃 2、修改Qt程序的Makefile,
在图中位置增添-g参数,再进行编译 2、这里将程序设置成自启动,在启动脚本中也需要加上ulimit -c unlimited命令,
在程序执行之前执行该命令 3、同样将core文件与可执行文件放在电脑上的同一目录下,在命令行使用gdb进行源码级调试
同样代码错误也清楚显示出来 |
|小黑屋| 飞凌嵌入式 ( 冀ICP备12004394号-1 )
GMT+8, 2024-11-22 09:10
Powered by Discuz! X3.4
© 2001-2013 Comsenz Inc.