在具有许多函数和许多调用的大代码中,我希望在屏幕上打印或记录任何函数的回溯跟踪,包括任何其他信息,例如:
主调用函数A和A调用调用函数C的函数B。
如果我将打印放在函数C上,我希望它可以打印main::A::B::C - [any parameter value for debugging]或任何其他格式。
这将帮助我更快地调试我面临的问题。
注意:对于那些会回答我的人,你可以在每个函数上打印一张,就像我说过的,很多调用和很多流程。
发布于 2014-02-06 20:59:49
如果您使用的是g++,那么可以使用函数符号获得堆栈回溯。
当前的挑战是在引发异常的地方捕获堆栈跟踪的内容,然后将其传输到异常捕获的位置。为此,您可以使用Boost.Exception。创建boost::exception子类,然后在构造函数中捕获堆栈回溯。稍后,在捕获异常时,可以打印出跟踪或以其他方式使其可用。
另一个问题是,C++符号名将被损坏。如果希望使它们具有可读性,可以调用解魔 (同样,g++特定)。
正如您从上面看到的,答案是特定于平台的。对于其他编译器和运行时环境,可能有类似的解决方案。
https://stackoverflow.com/questions/21613721
复制相似问题