ldd指令用于区分哪些动态函数库包含在可执行二进制档案中。在Linux中,ldd指令主要是查询程序需要的共享库,那么ldd指令实际应该如何使用呢?下面,我给大家详细介绍一下Linux下ldd指令的 *** 作方法。让我们学习和训练一些感兴趣的朋友。
LD指令用来区分一个可执行二进制文件有哪些动态函数库。
LinuxLdd的主要参数表明:
-version复制ldd的版本信息。
-v-Verbose复制所有信息内容,例如包含标记的版本信息。
-d-data-relocs实现标记重新分配,并报告总体目标的缺失(仅提供ELF格式)
-r-function-relocs重新配置总体目标和功能,并报告缺失的总体目标和功能(仅提供ELF格式)
-帮助使用信息内容
如果cmd中给定的库名包含'/',则此程序的libc5版本号将使用它作为库名;否则,它将在规范部分中搜索库。在当前目录下运行一个共享库,前缀为"。/"。
不正确:
Ld无法在a.out格式的共享库中工作。
Ldd不能在一些非常老的a.out程序上工作,这些程序是在C语言编译器ldd发布之前很久建立的。如果你一直对这类程序应用ldd,程序会尝试argc=0的运算方法,结果是无法预料的。
例如:
ldd/bin/bash
然而,ldd本身不是一个程序,而只是一个外壳脚本:
$哪个ldd
/usr/bin/ldd
$file/usr/bin/ldd
/usr/bin/ldd:Bourne-Againshell脚本文本可执行文件
ldd指令实际上是通过设置一些环境变量来完成的(换句话说,ldd的功效只是设置一些环境变量的值)
例如LD_TRACE_LOADED_OBJECTS
如果它的值不是空。
$exportLD_TRACE_LOADED_OBJECTS=1
美元/美元
linux-gate.so.1=》(0xb7fac000)
librt.so.1="/lib/TLS/i686/cmov/librt.so.1(0xb7f93000)
libselinux.so.1="/lib/libselinux.so.1(0xb7f79000)
libacl.so.1="/lib/libacl.so.1(0xb7f70000)
libc.so.6="/lib/TLS/i686/cmov/libc.so.6(0xb7e0d000)
libpthread.so.0="/lib/TLS/i686/cmov/libpthread.so.0(0xb7df4000)
/lib/ld-linux.so.2(0xb7fad000)
libdl.so.2="/lib/TLS/i686/cmov/libdl.so.2(0xb7df0000)
libattr.so.1="/lib/libattr.so.1(0xB7DEA000)
撤消此环境变量,ls可以恢复并再次应用:
$取消设置LD_TRACE_LOADED_OBJECTS
$ls/usr/
bin游戏包括liblib32lib64本地sbinsharesrcX11R6
大量的环境变量:
1、LD_TRACE_LOADED_对象
2、LD_WARN
3、LD_BIND_NOW
4、LD_库_版本
5、LD_VERBOSE
6、LD_DEBUG
LD默认设置打开的环境变量是:LD_TRACE_LOADED_OBJECTS=1。
其他独立变量(组合值)每个都匹配一些选项:
-d,-data-relocs-》LD_WARN=yes
-r,-function-relocs-"LD_warn和LD_BIND_NOW=yes
-u,-未使用-》LD_DEBUG="未使用"
-v,-verbose-》LD_VERBOSE=yes
LD_TRACE_LOADED_OBJECTS是必需的环境变量,其他视具体情况而定。
ldd指令的本质是:/lib/ld-linux.so.*
我们可以从上面的内容(在ls/usr中)了解到:/lib/ld-linux.so.2(0xb7fad000)。
$ls-l/lib/ld-linux.so.*
lrwxrwxrwx1rootroot92009-09-0522:54/lib/LD-Linux.so.2-》LD-2.9.so
刚编译完程序的文档可能是:/lib/ld.so,如果是libc5,就是/lib/ld-linux.so.1,而glibc2应该是/lib/ld-linux.so.2。
$/lib/LD-Linux.so.2-list/bin/ls
linux-gate.so.1=》(0xb8050000)
librt.so.1="/lib/TLS/i686/cmov/librt.so.1(0xb8037000)
libselinux.so.1="/lib/libselinux.so.1(0xb801d000)
libacl.so.1="/lib/libacl.so.1(0xb8014000)
libc.so.6="/lib/TLS/i686/cmov/libc.so.6(0xb7eb1000)
libpthread.so.0="/lib/TLS/i686/cmov/libpthread.so.0(0xb7e98000)
/lib/ld-linux.so.2(0xb8051000)
libdl.so.2="/lib/TLS/i686/cmov/libdl.so.2(0xb7e94000)
libattr.so.1="/lib/libattr.so.1(0xb7E8e000)
我们可以看到,以上等同于lddls。
ldd可以得到的共享库文件实际上是根据加载ldconfig的指令建立的文档(/etc/ld.so.cache)。
默认的共享库文件检索/lib优先于/usr/lib,并且只有一两个文件目录。如果要添加其他方式,必须根据ldconfig指令准备相关文档。
通常,ld-linux.so会按以下顺序搜索共享库:
1.DT_RPATH或DT_RUNPATH段
2.环境变量LD_LIBRARY_PATH
3./etc/ld.so.cache文档中的路径,但如果可执行程序在连接的情况下添加了-znodelib选项,则会被绕过。
4.默认设置是/lib和/usr/lib,但是如果添加了-znodeflib,就会被绕过。
以下由其他网友填写:
1.起初,ldd不是一个可执行程序,而只是一个shell脚本。
2.ldd可以显示信息,实现控制模块的依赖性。其基本原理是设置一系列环境变量,如LD_TRACE_LOADED_OBJECTS、LD_WARN、LD_BIND_NOW、LD_LIBRARY_VERSION、LD_VERBOSE等。当LD_TRACE_LOADED_OBJECTS环境变量不是空时,当所有可执行程序都在运行时,只会显示信息控制模块的依赖关系,而程序并没有实际执行。为什么不在shell终端设备上测试一下,如下:
(1)导出LD_TRACE_LOADED_OBJECTS=1
(2)执行所有程序,如ls等。,并查看程序的运行结果。
3.ldd可以根据控制模块的依赖关系原理来显示信息,其本质是基于LD-Linux.so(ELF动态库的loader)。我们知道,ld-linux.so控制模块会在可执行控制模块程序中工作并获得决策权,所以在设置这些环境变量时,ld-linux.so选择显示信息可执行控制模块的依赖关系。
4.其实ld-linux.so控制模块是可以马上实现的,比如:/lib/LD-Linux.so.2-list程序(相当于ldd程序)ldd指令 *** 作方法(摘自ldd-help)
名称ldd-复制共享库的相互依赖性
考试大纲LDD[可选项目]。。。文件。。。
描述cmd上ldd输出指定的每个程序或共享库所需的共享库。
选择权
-版本
复制ldd的版本信息
-v-详细
复制所有信息内容,如包含标记的版本信息。
-d-数据-重定位
实施标记重新分配,并报告缺失的总体目标(仅提供ELF格式)
-r-function-relocs
重新配置总体目标和功能,并报告缺失的总体目标和功能(仅提供ELF格式)
-帮助使用信息内容
ldd的规范版本号与glibc2一起呈现。Libc5是在老版本之前出现的,现在仍然存在于一些系统软件中。libc5版本号中的长期选项不兼容。另一方面,glibc2版本号与-V选项不兼容,只提供等效的-version选项。
如果cmd中给定的库名包含'/',则此程序的libc5版本号将使用它作为库名;否则,它将在规范部分中搜索库。在当前目录下运行一个共享库,前缀为"。/"。
Ld无法在a.out格式的共享库中工作。
Ldd不能在一些非常老的a.out程序上工作,这些程序是在C语言编译器ldd发布之前很久建立的。如果你一直对这类程序应用ldd,程序会尝试argc=0的运算方法,结果是无法预料的。
以上是我总结的Linux下应用ldd指令的 *** 作方法。ldd指令的专业知识是shell脚本制作,可以配合主参数的应用。ldd应用中的一些关键点需要注意。你掌握了吗?
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)