linux没打印debug信息,linux C++中输出debug和trace信息

(这里指LINUX G++环境)

一,三个重要的宏:

1 __LINE__ 当前的行号

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

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

二,打印stack trace

通过两个函数:

backtrace();

backtrace_symbols();

需要 -g -rdynamic 参数

#include  

#include  

#include    "string.h"

#include    "stdlib.h"

#include  

voidprint_trace();

voidtest();

voidprint_trace (void)

{

void*array[10];

size_tsize;

char**strings;

size_ti;

size = backtrace (array, 10);

strings = backtrace_symbols (array, size);

printf ("Obtained %zd stack frames.\n", size);

for(i = 0; i 

printf ("%s\n", strings[i]);

free (strings);

}

voidtest()

{

print_trace();

}

intmain(intargc,char*argv[])

{

printf("%d\n", __LINE__);

printf("%s\n", __FILE__);

printf("%s\n", __PRETTY_FUNCTION__);

test();

return0;

}

编译和输出

:!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]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值