gpt4 book ai didi

c++ - 如何使用 GDB 从 C++ 函数步调试到 std::function 用户代码?

转载 作者:行者123 更新时间:2023-12-01 13:38:03 26 4
gpt4 key购买 nike

例如,与:

#include <functional>
#include <iostream>

int myfunc(int i){ return i + 1; }

int main() {
std::function<int(int)> f = myfunc;
int i = f(1);
std::cout << i << std::endl;
}

编译:
g++ -ggdb3 -O0 -std=c++11 -Wall -Wextra -pedantic -o main.out main.cpp

如果我尝试做一个 step进入电话 f(1) ,然后它首先引导我进入 C++ 标准库代码,我要么必须认真思考并做正确的事情 next/ step顺序,或者哑巴打 step 17 次才达到实际 myfunc称呼。

有没有更简单的方法来解决这个问题,也许使用一些现有的 GDB/Python 脚本?

这基本上是由 Microsoft 人员为 Visual Studio 完成的,如: https://devblogs.microsoft.com/cppblog/improving-the-debugging-experience-for-stdfunction/

我喜欢它可以在 Ubuntu 中默认进入 stdlibc++ 并且有 already used it before ,但如果 GDB 能进入 std::function 那就太棒了默认情况下,用户代码,并有一些其他机制进入 libstdc++ 对于这种特定情况。

我很想变得有点厚颜无耻,只使用以下重复命令 n 次的 Python GDB 脚本: gdb - perform a command n times这让我可以做:
repeat-cmd 17 s

相关: QtCreator debugger: step into std::function

在 Ubuntu 18.04、GDB 8.1、GCC 7.4 中测试。

最佳答案

在您的用例中不起作用的第一件事是

gdb skip -gfile bits/*.h



正如您已经提到的,这也将跳过从 std 库中调用的代码。

下一个想法:跳过具有“已知名称”的函数。正如我们通常所拥有的 std::在函数名a前面使用了以下 .gdbinit .它看起来好多了:
sys.path.insert(0, '/usr/share/gcc-9/python/')
from libstdcxx.v6.printers import register_libstdcxx_printers
register_libstdcxx_printers (None)

import gdb
import re

def stop_handler(event):
frame_name = gdb.selected_frame().name();
if re.search("(operator new.*)|(^__gnu_cxx::.*)|(^std::.*)", frame_name) != None:
gdb.execute("step")

gdb.events.stop.connect(stop_handler)
end

我现在搜索了一段时间以找到将当前文件/行号组合放入 python 中的东西,但没有找到任何东西。是否有任何 python 访问当前文件名和行号?如果是这样,在这种情况下这将简单得多。如果有人可以在这里添加一些信息就好了!

备注:在 ddd 中这不会很好地工作,因为来自 python 的内部步骤不会被 gui 识别。所以绿色箭头停留在最后一步的线上,而不是当前的线上。如果有人在这种情况下也知道一个技巧,欢迎任何帮助!

更新:

如果您使用以下作为 .gdbinit
python
import sys
sys.path.insert(0, '/usr/share/gcc-9/python/')
from libstdcxx.v6.printers import register_libstdcxx_printers
register_libstdcxx_printers (None)

import gdb
import re

def stop_handler(event):
sal = gdb.selected_frame().find_sal()
if sal == None:
gdb.execute("step")
else:
symtab = sal.symtab;
if symtab == None:
gdb.execute("step")
else:
file_name = symtab.fullname();
if re.search("(.*bits.*)", file_name ) != None:
gdb.execute("step")

gdb.events.stop.connect(stop_handler)
end

在我的电脑上一切正常。作为附加提示:如果使用 ddd ,您可以打开回溯窗口,然后绿色箭头也将遵循 python 内部 gdb 步骤。这对我来说非常有效!感谢提问! :-)

也许可以更新正则表达式以适合过滤更多外部库或更具选择性。

关于c++ - 如何使用 GDB 从 C++ 函数步调试到 std::function 用户代码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59429401/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com