在kernel里可以用dump_stack()打出内核函数调用关系,在应用程序里可以用backtrace+backtrace_symbols打出调用栈。一般来说应用程序里手动跟踪可能更方便,或者crash后用gdb打出调用关系也很简单,但某些特殊需求里还是得请backtrace出来。
这两个函数需要加 <execinfo.h> 头文件,两个函数描述如下:
int backtrace(void **buffer,int size)
---该函数用与获取当前线程的调用堆栈,获取的信息将会被存放在buffer中,它是一个指针数组
char ** backtrace_symbols (void *const *buffer, int size)
--- 从backtrace函数获取的信息转化为一个字符串数组.它包括函数名,函数的偏移地址,和实际的返回地址
从https://www.cnblogs.com/mickole/p/3246702.html 里copy了一个测试程序:
#include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
void myfunc3(void)
{
int j, nptrs;
void *buffer[100];
char **strings;
nptrs = backtrace(buffer, 100);
printf("backtrace() returned %d addresses\n", nptrs);