linux C++中輸出debug和trace信息

     (這裏指LINUX G++環境)

一,三個重要的宏:

1 __LINE__ 當前的行號

2 __FILE__ 當前的文件名(xxx.cpp)

3 __PRETTY_FUNCTION__/__FUNCTION__ 帶簽名和不帶簽名的函數名

 

二,打印stack trace

通過兩個函數:

backtrace();

backtrace_symbols();

需要 -g -rdynamic 參數

  1. #include  <stdio.h> 
  2. #include  <exception> 
  3. #include    "string.h" 
  4. #include    "stdlib.h" 
  5. #include  <execinfo.h> 
  6.  
  7. void print_trace(); 
  8. void test(); 
  9.  
  10. void print_trace (void
  11.     void *array[10]; 
  12.     size_t size; 
  13.     char **strings; 
  14.     size_t i; 
  15.  
  16.     size = backtrace (array, 10); 
  17.     strings = backtrace_symbols (array, size); 
  18.  
  19.     printf ("Obtained %zd stack frames.\n", size); 
  20.  
  21.     for (i = 0; i < size; i++) 
  22.         printf ("%s\n", strings[i]); 
  23.  
  24.     free (strings); 
  25.  
  26. void test() 
  27.     print_trace(); 
  28.  
  29. int main(int argc, char *argv[]) 
  30.     printf("%d\n", __LINE__); 
  31.     printf("%s\n", __FILE__); 
  32.     printf("%s\n", __PRETTY_FUNCTION__); 
  33.  
  34.     test(); 
  35.     return 0; 

 

編譯和輸出

:!g++ -Wall -g -rdynamic ddd.cpp;./a.out

35

ddd.cpp

int main(int, char**)

Obtained 5 stack frames.

./a.out(_Z11print_tracev+0x16) [0x40090e]

./a.out(_Z4testv+0x9) [0x40098d]

./a.out(main+0x50) [0x4009e0]

/lib64/tls/libc.so.6(__libc_start_main+0xdb) [0x302af1c4bb]

./a.out(__gxx_personality_v0+0x42) [0x40086a]

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章