ldd不是一个可执行程序,而只是一个shell脚本
体积小,需要链接动态库,对各平台的兼容性可能不太好
参考:
https://www.linuxsong.org/2015/04/mac-os-x-ldd-strace
http://man.linuxde.net/ldd
https://coolshell.cn/articles/1626.html
https://stackoverflow.com/questions/1685483/how-can-i-examine-contents-of-a-data-section-of-an-elf-file-on-linux
https://www.jianshu.com/p/ef462437b999
一、现象
file not found ***
二、原因分析
要运行的文件缺少依赖库
三、问题解决
1、ldd 程序文件
列出依赖,查看缺少的文件
2、whereis/find等命令查找依赖文件是否在其它位置存在
3、将文件复制到指定的目录,这个目录必须是程序启动时可以加载的目录,一般通过LD_LIBRARY_PATH指定
ldd命令用于输出程序或者库文件所依赖的共享库列表。
语法
选项
参数
文件:指定可执行程序或者文库。
ldd原理
首先,ldd不是一个可执行程序,而只是一个shell脚本。
ldd能够显示可执行模块的dependency,其原理是通过设置一系列的环境变量,如下: LD_TRACE_LOADED_OBJECTS、LD_WARN、LD_BIN_NOW、LD_LIBRARY_VERSION、LD_VERBOSE 等。当 LD_TRACE_LOADED_OBJECTS 环境变量不为空时,任何可执行程序在运行时,它都只会显示模块的dependency,而程序并不真正执行。测试结果如下:
ldd 显示可执行模块的dependency的工作原理,其实质是通过ld-linux.so(elf动态库的装载器)来实现的。ld-linux.so模块会先于executable模块程序工作,并获得控制权。因此当上述的那些变量设置时,ld-linux.so选择了显示可执行模块的dependency。
ld-linux.so读取可执行程序的头信息,这些信息采用 Executable and Linking Format 或者(ELF)格式。 它们通过这些消息,来确定哪些库是必须的,以及哪些库需要加载。 然后执行动态链接,把可执行程序当中所有的地址指针与需要加载的库联系起来, 这样程序就可以运行了。
实际上可以直接执行ld-linux.so模块,如: /lib64/ld-linux-x86-64.so.2 --list ./a.out (这相当于 ldd a.out )。
示例
通过上面的信息,我们可以得到以下几个信息:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)