在一个具有许多功能和许多调用的大代码中,我想在屏幕上打印或记录任何功能以及任何其他信息的回溯记录,例如:

主调用函数A和A调用调用函数C的函数B。

如果我在函数C上打印,我希望它打印main::A::B::C - [any parameter value for debugging]或任何其他格式。

这将帮助我更快地调试遇到的问题。

注意:对于那些会回答我的人,您可以在每个函数上打印,就像我说的很多调用和很多流程一样。

最佳答案

如果使用的是g++,则可以使用backtrace or backtrace_symbols函数获得堆栈回溯。

面临的挑战是在引发异常的点捕获堆栈跟踪的内容,然后将其传输到捕获异常的位置。为此,您可以使用Boost.Exception。创建boost::exception的子类,然后在构造函数中捕获堆栈回溯。稍后,当捕获异常时,您可以打印出跟踪或以其他方式使其可用。

另一个问题是C++符号名称将被修饰。如果要使它们可读,可以调用abi::__cxa_demangle(同样,特定于g++)。

从上面可以看到,答案是特定于平台的。对于其他编译器和运行时环境,可能会有类似的解决方案。

关于c++ - C++中的追溯,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21613721/

10-10 18:11