使用GDB调试C程序需先编译时加-g选项,再用gdb ./program加载;通过break设置断点,run运行程序;用step、next单步执行,continue继续运行;print查看变量值,backtrace查看调用栈;可attach附加到运行进程,结合实际问题多练习以熟练掌握调试技巧。

调试C程序在Linux下最常用的工具是GDB(GNU Debugger),它能帮助你查看程序运行时的内部状态,定位崩溃、逻辑错误等问题。下面是一个完整的GDB断点调试教程,适合初学者和中级开发者快速上手。
启动GDB并加载程序
要使用GDB调试C程序,首先需要在编译时加入调试信息。使用 -g 选项:
gcc -g -o myprogram myprogram.c然后用GDB加载可执行文件:
gdb ./myprogram设置断点与运行程序
进入GDB交互界面后,可以设置断点来暂停程序执行。
- 在函数处设断点: break main
- 在指定行号设断点: break 10
- 在文件某行设断点: break myprogram.c:15
设置好断点后,运行程序:
run也可以带命令行参数:
run arg1 arg2控制执行流程
程序在断点处暂停后,你可以逐步执行并观察行为。
- 单步执行(进入函数): step
- 单步执行(跳过函数): next
- 继续运行到下一个断点: continue
- 退出当前函数: finish
查看变量和内存状态
调试过程中,经常需要检查变量值或内存内容。
- 打印变量值: print variable_name
- 连续监视变量: display count(每次停顿时自动显示)
- 打印数组元素: print array[0]@5(显示前5个元素)
- 查看内存地址内容: x/4xw &var(以16进制显示4个字)
查看调用栈信息
当程序崩溃或在断点暂停时,查看函数调用路径非常有用。
- 显示当前调用栈: backtrace 或 bt
- 切换到某一层栈帧: frame 2
- 查看当前栈帧局部变量: info locals
处理段错误等异常
如果程序发生段错误(Segmentation Fault),可以用GDB定位问题。
先让GDB运行程序直到崩溃:
run程序崩溃后立即输入:
backtrace通常可以看到出错的具体函数和行号,结合 print 查看指针是否为NULL或越界访问。
附加到正在运行的进程
有时你想调试一个已经在运行的程序,可以这样操作:
gdb ./myprogram PID或者在GDB中使用:
attach PID调试完成后记得用 detach 解除附加。
基本上就这些。熟练掌握GDB后,排查C语言中的空指针、数组越界、逻辑错误会变得高效很多。关键是多练习,在真实项目中尝试加断点、查看变量、分析栈回溯。










