我的问题与此SO post和其他一些alike有关。我想知道调用函数的名称,因为在断言失败时,我不知道哪个函数向被调用者传递了一个垃圾值。一种方法是检查所有可以调用此函数的函数,但这非常麻烦。
即使平台依赖,您能建议更好的解决方案吗?我正在使用g ++ 4.6。提前谢谢。
答案 0 :(得分:5)
glibc中有backtrace个函数。它可以让您使用调用函数或方法进行完整跟踪。
如果您只想要来电者, gcc 中的specific functions就是为此:
__builtin_frame_address(int level);
使用level == 1
您具有来电功能。有关如何使用它的详细信息,请参阅this post。
以下是文档中的示例程序:
#include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>
/* Obtain a backtrace and print it to stdout. */
void
print_trace (void)
{
void *array[10];
size_t size;
char **strings;
size_t i;
size = backtrace (array, 10);
strings = backtrace_symbols (array, size);
printf ("Obtained %zd stack frames.\n", size);
for (i = 0; i < size; i++)
printf ("%s\n", strings[i]);
free (strings);
}
/* A dummy function to make the backtrace more interesting. */
void
dummy_function (void)
{
print_trace ();
}
int
main (void)
{
dummy_function ();
return 0;
}
答案 1 :(得分:4)
请参阅backtrace()
。
e.g。
#include <execinfo.h>
#include <stdio.h>
void bar() {
void* callstack[128];
int i, frames = backtrace(callstack, 128);
char** strs = backtrace_symbols(callstack, frames);
for (i = 0; i < frames; ++i) {
printf("%s\n", strs[i]);
}
free(strs);
}
int foo() {
bar();
return 0;
}
int main() {
foo();
return 0;
}
输出:
0 a.out 0x0000000100000e24 bar + 28
1 a.out 0x0000000100000e81 foo + 14
2 a.out 0x0000000100000e96 main + 14
3 a.out 0x0000000100000e00 start + 52
4 ??? 0x0000000000000001 0x0 + 1
请参阅: