我通常以以下方式运行程序:
./a.out arg1 arg2 <file
我想使用gdb调试它。
我知道该set args
功能,但是只能在gdb提示符下使用。
我通常以以下方式运行程序:
./a.out arg1 arg2 <file
我想使用gdb调试它。
我知道该set args
功能,但是只能在gdb提示符下使用。
Answers:
你可以这样做:
gdb --args path/to/executable -every -arg you can=think < of
魔力正在--args
。
只需run
在gdb命令控制台中键入即可开始调试。
--args
那么没有任何参数传递给可执行文件,因此几乎没有歧义。
argv[0]
是可执行文件的名称
gdb
自身输入重定向到of
文件,并导致gdb尝试从文件执行命令
如果您想使用裸run
命令gdb
执行带有重定向和参数的程序,则可以使用set args
:
% gdb ./a.out
(gdb) set args arg1 arg2 <file
(gdb) run
我无法通过--args
参数实现相同的行为,因此无法进行gdb
重定向,即
% gdb --args echo 1 2 "<file"
(gdb) show args
Argument list to give program being debugged when it is started is "1 2 \<file".
(gdb) run
...
1 2 <file
...
实际上这是重定向gdb本身的输入,而不是我们在这里真正想要的
% gdb --args echo 1 2 <file
zsh: no such file or directory: file
在您的项目上启动GDB。
转到项目目录,您已经在其中编译了项目可执行文件。发出命令gdb和可执行文件的名称,如下所示:
gdb projectExecutablename
这会启动gdb,并打印以下内容:GNU gdb(Ubuntu 7.11.1-0ubuntu1〜16.04)7.11.1版权所有(C)2016 Free Software Foundation,Inc. .....................键入“ apropos word”以搜索与“ word”相关的命令。 。从projectExecutablename ...中读取符号。(gdb)
在开始运行程序之前,您想要设置断点。break命令允许您这样做。要在名为main的函数的开头设置一个断点:
(gdb)b主
出现(gdb)提示符后,运行命令将开始运行可执行文件。如果要调试的程序需要任何命令行参数,则可以在run命令中指定它们。如果要在“ xfiles”文件(位于项目目录中的“ mulder”文件夹中)上运行程序,请执行以下操作:
(gdb)r mulder / xfiles
希望这可以帮助。
免责声明:此解决方案不是我的,它改编自https://web.stanford.edu/class/cs107/guide_gdb.html 这个gdb简短指南很可能是由斯坦福大学开发的。
只需debug
在命令行之前键入任何命令就可以gdb
在shell级别进行调试,这会很好吗?
在它下面的这个功能。它甚至可以与以下内容一起使用:
"$program" "$@" < <(in) 1> >(out) 2> >(two) 3> >(three)
这是一个您无法控制任何内容的调用,所有内容都是可变的,可以包含空格,换行符和shell元字符。在这个例子中,in
,out
,two
,和three
是必须不会受到伤害,其消耗的任意其它命令或产生数据。
在这样的环境中,以下bash
函数gdb
几乎干净地调用[ Gist ]:
debug()
{
1000<&0 1001>&1 1002>&2 \
0</dev/tty 1>/dev/tty 2>&0 \
/usr/bin/gdb -q -nx -nw \
-ex 'set exec-wrapper /bin/bash -c "exec 0<&1000 1>&1001 2>&1002 \"\$@\"" exec' \
-ex r \
--args "$@";
}
有关如何应用此示例:只需debug
在前面输入:
之前:
p=($'\n' $'I\'am\'evil' " yay ")
"b u g" "${p[@]}" < <(in) 1> >(out) 2> >(two) 3> >(three)
后:
p=($'\n' $'I\'am\'evil' " yay ")
debug "b u g" "${p[@]}" < <(in) 1> >(out) 2> >(two) 3> >(three)
而已。现在,使用进行调试绝对是轻而易举gdb
。除了一些细节或更多:
gdb
不会自动退出,因此在退出之前保持IO重定向打开gdb
。但是我将此称为功能。
您不能argv0
像和一样轻松地传递给程序exec -a arg0 command args
。请执行以下操作:exec-wrapper
更改"exec
为"exec -a \"\${DEBUG_ARG0:-\$1}\"
。
FD大于1000,通常处于关闭状态。如果有问题,请0<&1000 1>&1001 2>&1002
改为阅读0<&1000 1>&1001 2>&1002 1000<&- 1001>&- 1002>&-
您不能并行运行两个调试器。如果使用其他一些命令/dev/tty
(或STDIN),也可能会出现问题。要解决此问题,请替换/dev/tty
为"${DEBUGTTY:-/dev/tty}"
。在其他一些TTY类型中tty; sleep inf
,然后使用打印的TTY(即E. /dev/pts/60
)进行调试,如中所示DEBUGTTY=/dev/pts/60 debug command arg..
。这就是壳牌的力量,请习惯它!
功能说明:
1000<&0 1001>&1 1002>&2
移走前3个FD
0</dev/tty 1>/dev/tty 2>&0
恢复前三个FD指向您当前的TTY。这样就可以控制了gdb
。/usr/bin/gdb -q -nx -nw
在外壳上运行gdb
调用gdb
-ex 'set exec-wrapper /bin/bash -c "exec 0<&1000 1>&1001 2>&1002 \"\$@\""
创建一个启动包装程序,该程序将还原保存到1000及更高版本的前3个FD-ex r
使用启动程序 exec-wrapper
--args "$@"
传递给定的参数那不是那么容易吗?
r
是缩写run
,您可以使用任何参数跟随它。像这个问题一样,可能是:r arg1 arg2 <file
或可能是run arg1 arg2 <file