GDB代码调试与使用
Linux下GDB调试代码
源代码
编译生成执行文件
gcc -g test.c -o test
使用GDB调试
- 启动GDB:gdb test
- 从第一行列出源代码:list
- 直接回车表示,重复上一次命令
- 设置断点,在源程序16行处:break 16
- 设置断点,在函数func()入口处:break func
- 查看断点信息:info break
- 运行程序:run
- 在断点处停住
- 单条语句执行:next
- 继续运行程序:continue【程序输出:result[1-100]=5050】
- 打印变量i的值:print i
- 打印变量sum的值:p sum
- 查看函数堆栈:bt
- 推出函数:finish
- 继续运行程序:continue【程序输出:result[1-250]=31125;程序退出,调试结束:Inferior 1 (process 4040) exited normally】
- 退出GDB:quit
使用GDB
启动GDB
gdb [program] program也就是你的执行文件,一般在当前目录下。
gdb [program] core 用gdb同时调试一个运行程序core文件,core是程序非法执行后core dump后产生的文件。
gdb [program] [PID] 如果你的程序是一个服务程序,那么你可以指定这个服务程序运行是的进程ID。gdb会自动attach上去,并调试它。program应该在PATH环境变量中搜索到。
GDB的命令概貌
启动GDB后,就进入了GDB的调试环境,就可以使用GDB的命令开始调试程序了,GDB的命令可以使用help命令来查看:
GDB的命令很多,GDB把之分成很多种类。help命令只是列出了GDB的命令种类,如果要看种类中的命令,使用help [class]命令,如:help breakpoints,查看设置断点的所有命令。也可以直接help [command]来查看命令的帮助。
-
GDB中,输入命令时,可以不用打全命令,只用打命令的前几个字符就可以了,当然,命令的前几个字符要标志着一个唯一的命令,在linux下,可以敲击两次TAB键来补齐命令的全称,如果有重复的,GDB会把其列出来。
- 示例一:在进入函数func时,设置一个断点。可以敲击break func,或者直接就是b func
- 示例二:敲入b按两次TAB键,你会看到所有b开头的命令:
- 示例三:只记得函数的前缀,可以这样:(gdb)b make_<按TAB键>,GDB把所有make开头的函数全部列出来给你查看。
退出GDB
- 使用quit命令或者q命令。
在GDB中运行程序
当以gdb [program]方式启动GDB后,GDB会在PATH路径和当前目录中所搜[program]的源文件。如要确认GDB是否读到源文件,可使用l或者list命令,看GDB是否能列出源代码。
在gdb中,运行程序使用r或者run命令。
调试已运行的程序
在UNIX下用ps查看正在运行的程序的PID(进程ID),然后用gdb [program] PID格式挂接正在运行的程序。
先用gdb [program]关联上源代码,并进行GDB,在GDB中用attach命令来挂接进程的PID,并用detach来取消挂接的程序。
暂停程序运行
调试程序中,暂停进程运行时必须的,GDB可以方便的暂停程序的运行。你可以设置程序在哪停住,在什么条件下停住,在收到什么信号时停住等等。你便于你查看运行的变量,以及运行时的流程。
当进程被GDB停住时,你可以使用infoprogram来查看程序是否在运行、进程号、被暂停的原因。
-
在GDB中,我们可以有以下几种暂停方式:断点(breakpoint)、观察点(watchpoint)、捕捉点(catchpoint)、信号(signals)、线程停止(threadstops)。如果要恢复程序运行,可以使用c或者continue命令。
设置断点(breakpoint)
我们用break命令设置断点。下面有几点设置断点的方法:
break [function] 在进入指定函数时停住;
break [linenum] 在指定行号停住;
breakfilename:linenum 在源文件filename的linenum行处停住;
breakfilename:function 在源文件filename的function函数的入口处停住;
break break命令没有参数时,表示在下一条指令处停住;
break…if<condition> …可以是上述的参数,condition表示条件,在条件成立时停住。比如在循环体中,可
以设置break if i=100,表示当i为100时停住程序。 -
查看断点时,可使用命令info命令,如下所示:(注:n表示断点号)
- info breakpoints [n]
- info break [n]
恢复程序运行
-
当程序被停住后,可以用continue命令恢复程序的运行直到程序结束,或下一个断点的到来。也可以使用step或next命令单步跟踪程序。
- continue [ignore-count]
- c [ignore-count]
- fg [ignore-count] 恢复程序运行,直到程序结束,或是下一个断点到来。Ignore-count表示忽略其后的断点次数。continue,c,fg三个命令都是一样的意思。
- step [count] 单步跟踪,如果有函数调用,它会进入该函数。
- next [count] 同样单步跟踪,如果有函数调用,它不会进入函数。
- finish 运行程序,直到当前函数完成返回。并打印函数返回时的堆栈地址和返回值及参数值信息。