在linux代碼中打印函數調用的堆棧的方法


之前一直有這樣的需求,當時問到,也沒搜到方法,現在竟然既問到了,也搜到了,哎,世事真是不能強求啊!

 

Linux內核調試中,經常用到的打印函數調用堆棧的方法非常簡單,只需在需要查看堆棧的函數中加入:

dump_stack();或 __backtrace();即可。

 

dump_stack()在~/kernel/ lib/Dump_stack.c中定義

 

void dump_stack(void)
{
 printk(KERN_NOTICE
  "This architecture does not implement dump_stack()/n");
}

__backtrace()的定義在~/kernel/arch/arm/lib/backtrace.S中

 

ENTRY(__backtrace)
  mov r1, #0x10
  mov r0, fp

 

在linux應用程序調試中,使用的方法是:

 

backtrace
backtrace_symbols

 

可以在函數中加入如下代碼:

 void *bt[20]; 
 char **strings; 
 size_t sz;

 sz = backtrace(bt, 20); 
 strings = backtrace_symbols(bt, sz);
        for(i = 0; i < sz; ++i)
                fprintf(stderr, "%s/n", strings[i]);

 

還有一個帖子總結了在各種平台和語言中打印backtrace的方法:

http://blog.csdn.net/csucrab/archive/2010/06/17/5675686.aspx


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM