bash-3.00$ file foo foo: ELF 32-bit LSB executable,Intel 80386,version 1 (SYSV),for GNU/Linux 2.6.21,dynamically linked (uses shared libs),not stripped
但是,如果我在这个文件上运行ldd,那么它就无法获取二进制文件依赖的.so文件。
bash-3.00$ ldd foo not a dynamic executable bash-3.00$
bash-3.00$ readelf -d foo Dynamic segment at offset 0x17c810 contains 70 entries: Tag Type Name/Value 0x00000001 (NEEDED) Shared library: [libdl.so.2]
加载boost的共享库时出错
在Linux上pipe理共享库的常用方法是什么?
如何使用gcc在ubuntu下从静态库中创build共享库
如何通过系统库强制使用本地共享库?
Linux共享库的init和deinit也使用c ++静态初始化
gcc在指定的path中链接共享库,但不在标准path中
关于共享库的问题
在Linux中共享可执行的内存页面?
Linux,共享库使用主程序中的函数而不是其他共享库
就像其中一个评论所说 – 你试过在64位系统上使用ldd来检查一个32位的ELF对象。 ldd使用标准的动态链接器来跟踪依赖关系,所以如果你的平台没有被检查的ELF对象所需的链接器,ldd将会失败。 在这些情况下,Readelf和objdump更加健壮。
请注意,在Fedora 21中,为了让ldd识别32位.so文件,我必须安装以下内容:
sudo yum install glibc.i686 libgcc.i686 libstdc++.i686 glibc-devel.i686
我不确定哪一个修复了我在ldd中看到的“不是动态的可执行文件”错误。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。