我正在Linux/gcc
我目前使用以下内容来获取自定义抛出异常的堆栈跟踪。 Demangled
函数名称和line numbers
符合预期,但我希望避免使用addr2line
来完全控制输出字符串的格式。
static void posix_print_stack_trace()
{
int i, trace_size = 0;
char **messages = (char **)NULL;
trace_size = backtrace(stack_traces, MAX_STACK_FRAMES);
messages = backtrace_symbols(stack_traces, trace_size);
for (i = 0; i < trace_size; ++i)
{
if (addr2line(program_invocation_name, stack_traces[i]) != 0)
{
printf(" error determining line # for: %s\n", messages[i]);
}
}
if (messages) { free(messages); }
}
static int addr2line(char const * const program_name, void const * const addr)
{
char addr2line_cmd[512] = {0};
sprintf(addr2line_cmd,"addr2line -C -f -p -i -e %.256s %p", program_name, addr);
return system(addr2line_cmd);
}
注意:使用-f
在堆栈跟踪中显示正在播放的函数名称,并使用-C
显示它们已解码。
问:是否有人能指出我的程序化解决方案?
(如果可能给我一些关于如何使它与MinGW/gcc
一起工作的建议。)
注意:或者可能只是以某种方式使用gdb
可以帮助获得更多自定义输出?
感谢您的帮助。
编辑:看起来对于Windows部分来说,它是可行的:https://stackoverflow.com/a/6207030/1715716
编辑:上述内容仅指向Microsoft Visual解决方案,因此对我来说最终毫无用处。
答案 0 :(得分:3)
你可能可以使用或改编(至少在Linux上,使用ELF和DWARF的系统)Ian Taylor的libbacktrace
,它目前在GCC源代码树中。见here;原则上它应该独立于GCC使用(前提是你遵守其类似BSD的许可)。