C语言 Linux 获取调用者函数名称

C语言 Linux 获取调用者函数名称,第1张

可以做到的,参考一下backtrace_symbols的实现以及相关原理,这里面比较复杂,也比较底层,一两句话说不清楚

你要是想通过_FUNCTION_这种方式来搞的话,可以通过如下方式:

#define m_fun(args) fun(__FILE__,__LINE__, args)

进行相应的替换即可

1.将ndk中的arm-Linux-androideabi-addr2line可执行文件的路径加入配置文件~/.bashrc中,例如:

export PATH=$PATH:~/dlna/Android-ndk-r6b/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin

2.使配置生效:source ~/.bashrc

3.使用工具。例如:arm-linux-androideabi-addr2line -C -f -e ~/workspace/DLNA/libs/armeabi/libctrlpt.so 0003deb4

其中,0003deb4为堆栈信息中pc的值。

这个问题很复杂。这得看你的二进制程序是否包含这些信息。这得看 编译选项 有没有包含 -s 。-s选项会剔除不需要的符号名。

正式二进制发布的软件是可以没有这些信息的。对于静态链接函数名在c/c++ 语言执行的过程中是不需要的,它是通过内存地址 去访问 内存,数据和代码。函数名用于 编译过程 和链接过程。对于动太链接在程序执行过程由ld.so 通过变量名去 动态的链接到某些库的指定函数。动态链接的符号名不可剔除。

说到底就是二进制程序如果包含变量名,就会显示。

实例

main.c:

int aaa=10

int myfunc(){

    return 5

}

int main(){

    int bbb=20

    aaa=20

    bbb=myfunc()

    return 0

} gcc -nostdlib main.c -o main_with_symbols

gcc -nostdlib main.c -o main_without_symbols

分别产生包含符号名 和不包含符号名的 可执行文件。

!122 ~/src/c_cpp % objdump -d main_with_symbols|grep myfunc

000000000040017c <myfunc>:

  4001a5:    e8 d2 ff ff ff           callq  40017c <myfunc>

!123 ~/src/c_cpp % objdump -d main_without_symbols|grep myfunc

!124 ~/src/c_cpp 1 %

很明显使用 -s 选项后 很多符号信息丢失,反汇编中也不包含相关符号名。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8457859.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-16
下一篇 2023-04-16

发表评论

登录后才能评论

评论列表(0条)

保存