URN Logo
UNIX Resources » Linux » China Linux Forum » C/C++编程版 » 33 » [精华] FAQ:如何在程序内部获得call back trace
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
[精华] FAQ:如何在程序内部获得call back trace
 
 
 
 
 
 
 
 
 
 
Subject: [精华] FAQ:如何在程序内部获得call back trace
Author: xh_joke    Posted: 2005-05-31 09:46    Length: 407 byte(s)
[Original] [Print] [Top]
在Linux的C语言程序中,如何得到目前程序运行的堆栈轨迹,类似于java里面的printStackTrace(),目的是用于调试。


我之前使用过一种笨方法就是设一个全局链表,每次进入一个functino就将名称加入链表,退出在del掉,因为使用宏和Linux的list_head结构,其实效率损失的不是太多(当然仅用于调试时了)。但是这方法实在有点太低级了,羞于见人阿。

请大家讨论一下。不要使用gdb等调试器。
----
/* ... */
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: lonelyflyer    Posted: 2005-05-31 11:03    Length: 227 byte(s)
[Original] [Print] [Top]

include <execinfo.h>

void * btinf[25];
int nSize = backtrace(btinf, sizeof btinf);
char ** symbols = backtrace_symbols(btinf, nSize);
----
最新研究表明:经常发短信的人智商会降低10%
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: xh_joke    Posted: 2005-05-31 11:41    Length: 478 byte(s)
[Original] [Print] [Top]

听军一席话,省编好多码阿!多谢!

另:刚刚测试发现,使用上面函数时最好编译时加参数 -rdynamic (其实时传给ld的参数),否则可能不会打印出函数名称,而代之以偏移量。

参考:
http://www.delorie.com/gnu/docs/glibc/libc_665.html
(还是平时学习不够啊,GNUlibc的文档里就有的。)


----
/* ... */
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: ACp    Posted: 2005-05-31 17:25    Length: 52 byte(s)
[Original] [Print] [Top]
好东西.原来就有这个需求.一直没写.现在看来没必要写了.
----
OnlyPc
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: zhangxp    Posted: 2005-05-31 21:59    Length: 50 byte(s)
[Original] [Print] [Top]
厉害!!

请问,,如何得知的??
----
弃我去者昨日之日不可留,乱我心者今日之日多烦忧!
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: xh_joke    Posted: 2005-05-31 22:56    Length: 97 byte(s)
[Original] [Print] [Top]

哦,精华了!那更是要谢谢孤独飞人了

这位兄弟看来是很少发短信的了!。
----
/* ... */
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: lonelyflyer    Posted: 2005-05-31 23:21    Length: 16 byte(s)
[Original] [Print] [Top]
读代码的偶然收获
----
最新研究表明:经常发短信的人智商会降低10%
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: zhangxp    Posted: 2005-06-01 08:05    Length: 112 byte(s)
[Original] [Print] [Top]
孤独飞人??

翻译成

“比翼单飞”

比较好。。。。
----
弃我去者昨日之日不可留,乱我心者今日之日多烦忧!
[Original] [Print] [Top]
Subject: [精华] Re: 讨论:如何在程序内部获得call back trace
Author: ACp    Posted: 2005-06-01 09:46    Length: 3,603 byte(s)
[Original] [Print] [Top]

#include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>

/* Obtain a backtrace and print it to stdout. */
void
print_trace (void)
{
void *array[10];
size_t size;
char **strings;
size_t i;

size = backtrace (array, 10);
strings = backtrace_symbols (array, size);

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

for (i = 0; i < size; i++)
printf ("%s ", strings[i]);

free (strings);
}

/* A dummy function to make the backtrace more interesting. */
void dummy_function(void);
void test(void){
dummy_function();
}
void test1(void){
test();
printf("ok");
}
void
dummy_function (void)
{
//test();
print_trace ();
}

int
main (void)
{
//dummy_function ();
test1();
//print_trace();
return 0;
}

输出:
Obtained 7 stack frames.
./test(print_trace+0x14) [0x804878c]
./test(dummy_function+0xb) [0x8048837]
./test(test+0xb) [0x804880d]
./test(test1+0xb) [0x804881a]
./test(main+0x15) [0x804884e]
/lib/i686/libc.so.6(__libc_start_main+0xc7) [0x4003eb77]
./test(backtrace_symbols+0x31) [0x80486ed]



color=red>我理解这个函数只能取得直接调用的轨迹。而无法得到下面这样代码的调用轨迹color=red>


#include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>

/* Obtain a backtrace and print it to stdout. */
void
print_trace (void)
{
void *array[10];
size_t size;
char **strings;
size_t i;

size = backtrace (array, 10);
strings = backtrace_symbols (array, size);

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

for (i = 0; i < size; i++)
printf ("%s ", strings[i]);

free (strings);
}

/* A dummy function to make the backtrace more interesting. */
void dummy_function(void);
void test(void){
//dummy_function();
}
void test1(void){
test();
printf("ok");
}
void
dummy_function (void)
{
test();
print_trace ();
}

int
main (void)
{
dummy_function ();
test1();
//print_trace();
return 0;
}
输出:
Obtained 5 stack frames.
./test(print_trace+0x14) [0x804878c]
./test(dummy_function+0x10) [0x8048834]
./test(main+0x15) [0x804884b]
/lib/i686/libc.so.6(__libc_start_main+0xc7) [0x4003eb77]
./test(backtrace_symbols+0x31) [0x80486ed]

没有得到test调用信息
----
OnlyPc
[Original] [Print] [Top]
Subject: [精华] Re: FAQ:如何在程序内部获得call back trace
Author: xh_joke    Posted: 2005-06-02 14:21    Length: 264 byte(s)
[Original] [Print] [Top]

刚刚无意中读到的,还没有试过,大家参考:
http://sourceforge.net/projects/goog-coredumper/

google,还真招人喜欢!
----
/* ... */
[Original] [Print] [Top]
« Previous thread
请问这样的一个用户空间网关应用程序程序如何实现?(高手请进)
C/C++编程版
33
Next thread »
site: Welcome to the Linux Assembly!
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 03:52:55, cost 0.046714067459106 ms.