c++ 打印调用堆栈的代码

MakeFile添加动态链接库

如果没有这个库,请安装.

LIB                += -lunwind

#define UNW_LOCAL_ONLY

#include 

#include 

#include 

#include 

 

        void backtrace()

         {

            unw_cursor_t cursor;

            unw_context_t context;

 

            // Initialize cursor to current frame for local unwinding.

            unw_getcontext(&context);

            unw_init_local(&cursor, &context);

 

            // Unwind frames one by one, going up the frame stack.

            while (unw_step(&cursor) > 0) {

                unw_word_t offset, pc;

                unw_get_reg(&cursor, UNW_REG_IP, &pc);

                if (pc == 0) {

                break;

                }

                std::printf("0x%lx:", pc);

 

                char sym[256];

                if (unw_get_proc_name(&cursor, sym, sizeof(sym), &offset) == 0) {

                char* nameptr = sym;

                int status;

                char* demangled = abi::__cxa_demangle(sym, nullptr, nullptr, &status);

                if (status == 0) {

                    nameptr = demangled;

                }

                std::printf(" (%s+0x%lx)\n", nameptr, offset);

                std::free(demangled);

                } else {

                std::printf(" -- error: unable to obtain symbol name for this frame\n");

                }

            }

        }

 

 

 

效果大概是这个样子.

c++ 打印调用堆栈的代码_第1张图片

你可能感兴趣的:(杂七杂八,c++,c语言)