打印函数调用栈信息

01.<pre class="cpp" name="code"></pre><br>  
02.<pre class="cpp" name="code">void XXX_debug_print_trace(void)  
03.{  
04.    int j, nptrs;  
05.    void *buffer[100];  
06.    char **strings;  
07.  
08.    nptrs = backtrace(buffer, 100);  
09.  
10.    strings = backtrace_sysbols(buffer, nptrs);  
11.    if(NULL == strings)  
12.    {  
13.        perror("backtrace_sysbols");  
14.        return;  
15.    }  
16.  
17.    for(j=0; j<nptrs; j++)  
18.    {  
19.        XXX_INFO("%s", strings[j]);//printf  
20.    }  
21.  
22.    free(strings);  
23.  
24.    return;  
25.}  
26.  
27.#ifndef XXX_ASSERT_DEBUG  
28.#define XXX_ASSERT(a) {}  
29.#else  
30.#define XXX_ASSERT(a)   \  
31.    do{ \  
32.        if(!(a)){   \  
33.            printf("Assert Bug:("#a") is wrong!\n");  \  
34.            usleep(100);    \  
35.            XXX_debug_print_trace();    \  
36.        }   \  
37.    }while(0)  
38.#endif
在Linux系统中,有多种方法可以打印函数调用栈。 ### 方法一:使用 `<execinfo.h>` 头文件中的函数 该方法可用于用户空间程序,代码示例如下: ```c #include <execinfo.h> #include <stdio.h> void print_callstack() { void *bt[30]; char **strings; size_t sz; sz = backtrace(bt, 30); strings = backtrace_symbols(bt, sz); for(int i = 0; i < sz; ++i) printf("%s\n", strings[i]); } ``` ### 方法二:使用内核函数 `dump_stack()` 在Linux内核代码中,可以使用 `dump_stack()` 函数将栈内容和回溯信息打印到内核日志中。使用时需要包含 `<linux/kernel.h>` 头文件,示例如下: ```c #include <linux/kernel.h> void some_kernel_function() { // ... dump_stack(); // ... } ``` ### 方法三:自定义打印函数调用栈函数 下面是一个更完整的用户空间程序示例,展示了如何自定义一个打印函数调用栈的函数: ```c #include <stdio.h> #include <execinfo.h> #define MAX_DEPTH 20 void PrintfStackFunName(void) { void *buff[MAX_DEPTH] = { 0 }; unsigned int depth = backtrace(buff, MAX_DEPTH); char **funName = backtrace_symbols(buff, depth); for (int i = 0; i < MAX_DEPTH; i++) { if (i >= depth) { break; } printf("i = %d, func = %s\n", i, funName[i]); } } void func4(void) { printf("%s [line] = %d\n", __FUNCTION__, __LINE__); PrintfStackFunName(); } void func3(void) { printf("%s [line] = %d\n", __FUNCTION__, __LINE__); func4(); } void func2(void) { printf("%s [line] = %d\n", __FUNCTION__, __LINE__); func3(); } void func1(void) { printf("%s [line] = %d\n", __FUNCTION__, __LINE__); func2(); } int main(void) { func1(); return 0; } ``` 将上述代码保存为一个 `.c` 文件,编译并运行,就可以看到函数调用栈的输出。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值