ltrace命令是用来跟踪进程调用库函数的情况,ltrace其实也是基于ptrace。我们知道,ptrace能够主要是用来跟踪系统调用,那么它是如何跟踪库函数呢?首先ltrace打开elf文件,对其进行分析。在elf文件中,出于动态连接的需要,需要在elf文件中保存函数的符号,供连接器使用。

语法格式:ltrace [参数]

常用参数:

-a 对齐具体某个列的返回值
-c 计算时间和调用,并在程序退出时打印摘要
-d 打印调试信息
-f 跟踪子进程
-l 只打印某个库中的调用

参考实例

最基本应用,不带任何参数:

[root@linuxcool ~]# ltrace ./a.out 

输出调用时间开销:

[root@linuxcool ~]# ltrace -T ./a.out 

显示系统调用:

[root@linuxcool ~]# ltrace -S ./a.out 

计算时间和调用,并在程序退出时打印摘要:

[root@linuxcool ~]# ltrace -c ./a.out 

打印调试信息:

[root@linuxcool ~]# ltrace -d ./a.out  
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。