5

引发 std::exception 时如何打印完整的调用堆栈?

4

1 回答 1

4

如果您使用 g++ (gcc) 并且不介意代码不可移植,您可以尝试遵循"tombarta"的明智话语:

(来自 tombarta 的无耻副本):

#include <execinfo.h>
void print_trace(FILE *out, const char *file, int line)
{
    const size_t max_depth = 100;
    size_t stack_depth;
    void *stack_addrs[max_depth];
    char **stack_strings;

    stack_depth = backtrace(stack_addrs, max_depth);
    stack_strings = backtrace_symbols(stack_addrs, stack_depth);

    fprintf(out, "Call stack from %s:%d:\n", file, line);

    for (size_t i = 1; i < stack_depth; i++) {
        fprintf(out, "    %s\n", stack_strings[i]);
    }
    free(stack_strings); // malloc()ed by backtrace_symbols
    fflush(out);
}

我自己没有尝试过,所以我不知道它是否有效。

于 2010-08-04T11:07:15.553 回答