C ++ получает стек вызовов из std :: exception - PullRequest
5 голосов
/ 31 июля 2010

как я могу напечатать полный стек вызовов при возникновении исключения std ::

1 Ответ

4 голосов
/ 04 августа 2010

Если вы используете 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);
}

Я сам не пробовал, поэтому не знаю, работает ли он.

...