5

std :: exceptionが発生したときに完全なコールスタックを出力するにはどうすればよいですか?

4

1 に答える 1

4

g++ (gcc) を使用していて、コードの移植性が気にならない場合は、「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 に答える