首页 > 解决方案 > 跟踪 gdb 中函数执行的所有变量

问题描述

我想跟踪 C 函数中所有变量的状态。

我知道我可以在 gdb 中使用 info 命令来获取当前上下文中的所有变量状态。

我可以使用 gdbinit 来自动化 gdb。

但我想做的是在函数处设置一个断点,然后在执行每一行 print 后执行 info 命令。

基本上,我想设置 2 个断点:一个在函数的开头,一个在同一个函数的结尾(我不知道怎么做),并在这两个点之间逐行执行。

我想要这样的东西在我的gdbinit

b <func_name>
commands
while <inside the function>:
   info locals
   next
end
run

有没有办法让上面显示的while循环?

标签: cautomationscriptinggdbgdbinit

解决方案


基本上,我想设置 2 个断点:一个在函数的开头,一个在同一函数的结尾(我不知道怎么做),并在这两个点之间逐行执行。

您可以在此处找到如何在函数末尾设置断点。但是,这里没有必要。

您可以使用$_caller_is()GDB 便利函数来完成当前例程的执行,并在它返回后停止。

例子:

int fn()
{
  int sum = 0;
  for (int j = 0; j < 5; j++) {
    sum += j;
  }
  return sum;
}

int main()
{
  return fn() - 10;
}

现在 GDB 会话:

gdb -q ./a.out
Reading symbols from ./a.out...
(gdb) b 4
Breakpoint 1 at 0x1130: file t.c, line 4.
(gdb) run
Starting program: /tmp/a.out

Breakpoint 1, fn () at t.c:4
4     for (int j = 0; j < 5; j++) {
(gdb) while $_caller_is("main")
 >info locals
 >next
 >end
j = 1431654464
sum = 0
5       sum += j;
j = 0
sum = 0
4     for (int j = 0; j < 5; j++) {
j = 0
sum = 0
5       sum += j;
j = 1
sum = 0
4     for (int j = 0; j < 5; j++) {
j = 1
sum = 1
5       sum += j;
j = 2
sum = 1
4     for (int j = 0; j < 5; j++) {
j = 2
sum = 3
5       sum += j;
j = 3
sum = 3
4     for (int j = 0; j < 5; j++) {
j = 3
sum = 6
5       sum += j;
j = 4
sum = 6
4     for (int j = 0; j < 5; j++) {
j = 4
sum = 10
7     return sum;
sum = 10
8   }
sum = 10
main () at t.c:12
12    return fn() - 10;
(gdb) q

PS 对于除了玩具问题之外的所有问题,这种调试方法效率极低不足(很少有有趣的状态完全由局部变量捕获)。


推荐阅读