这是目录
- gcc编译选项
- 二、实战
- 1、编译加上 CFLAGS += -ggdb
- 三级目录
gcc编译选项
1、-g 编译debug
debugging 选项:-g
gcc -g手册: 点击这里
-g一共分为4个等级:-g、-g0、-g1、-g3
其中g和g0是一个性质,不打开调试信息,g3保留所有信息。
-ggdb
生成供 GDB 使用的调试信息。这意味着使用最具表现力的可用格式(DWARF 2、stabs 或本机 格式,如果这些都不支持),包括 GDB 扩展,如果 完全有可能。
二、实战
记录实际项目中的调试。
使用nano pi跑多线程的时候出现了一段时间出发段错误,使用GDB调试如下:
1、编译加上 CFLAGS += -ggdb
make后执行
gdb ./app
运行一段时间后出现错误,
使用info threads打印线程相关信息
可以看见,当前处于2号线程。
使用bt打印堆栈信息
一目了然 栈中是从下往上执行的,及再mem_info_fun里面发生了错误。排查发现是没有做错误检查导致的,open返回失败时没有做错误判断,导致段错误。
修改如下: