加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

替代Linux上的backtrace(),可以找到静态函数的符号

发布时间:2020-12-14 01:01:13 所属栏目:Linux 来源:网络整理
导读:在手册页中,Linux上的backtrace()函数说: Note that names of “static” functions are not exposed,and won’t be available in the backtrace. 但是,启用调试符号(-g)后,addr2line和gdb等程序仍然可以获取静态函数的名称.有没有办法从进程内部以编程方式
在手册页中,Linux上的backtrace()函数说:

Note that names of “static” functions
are not exposed,and won’t be available in the backtrace.

但是,启用调试符号(-g)后,addr2line和gdb等程序仍然可以获取静态函数的名称.有没有办法从进程内部以编程方式获取静态函数的名称?

解决方法

如果您的可执行文件(和链接库)使用调试信息进行编译(即使用-g标记为gcc或g),那么您可以使用来自GCC内部的Ian Taylor的libbacktrace(已宣布 here) – 请参阅其代码 here

该库(BSD许可的免费软件)使用来自该进程链接的可执行文件和共享库的DWARF调试信息.请参阅其README文件.

请注意,如果使用优化进行编译,则可以内联某些函数(即使没有在源代码中明确标记内联,并且静态内联函数可能没有任何适当的自己的代码).然后回溯不会说明他们.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读