(这里指LINUX G++环境)

一,三个重要的宏:

1 __LINE__ 当前的行号

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

3 __PRETTY_FUNCTION__/__FUNCTION__ 带签名和不带签名的函数名

 

二,打印stack trace

通过两个函数:

backtrace();

backtrace_symbols();

需要 -g -rdynamic 参数

   
   
   
   
  1. #include   
  2. #include   
  3. #include    "string.h" 
  4. #include    "stdlib.h" 
  5. #include   
  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]