实际上ldd为您提供了绝对路径,其中包含您可以找到的应用程序共享库依赖项中的任何内容.
$ ldd v8test
linux-gate.so.1 => (0xb78b2000)
libz.so.1 => /usr/lib/libz.so.1 (0xb787e000)
librt.so.1 => /lib/i686/cmov/librt.so.1 (0xb7875000)
libcppunit-1.12.so.1 => /usr/lib/libcppunit-1.12.so.1 (0xb782c000)
libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0xb7604000)
libm.so.6 => /lib/i686/cmov/libm.so.6 (0xb75dd000)
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0xb75bf000)
libc.so.6 => /lib/i686/cmov/libc.so.6 (0xb7478000)
libpthread.so.0 => /lib/i686/cmov/libpthread.so.0 (0xb745f000)
libboost_system-mt.so.1.38.0 => /usr/lib/libboost_system-mt.so.1.38.0 (0xb745b000)
/lib/ld-linux.so.2 (0xb78b3000)
libdl.so.2 => /lib/i686/cmov/libdl.so.2 (0xb7456000)
libboost_thread-mt.so.1.38.0 => /usr/lib/libboost_thread-mt.so.1.38.0 (0xb7383000)
libboost_filesystem-mt.so.1.38.0 => /usr/lib/libboost_filesystem-mt.so.1.38.0 (0xb7370000)
libtinyxml.so.1 => /home/dmitry/tinyxml/libtinyxml.so.1 (0xb7359000)
libboost_regex-mt.so.1.38.0 => /usr/lib/libboost_regex-mt.so.1.38.0 (0xb728c000)
libmysqlclient_r.so.15 => /usr/lib/libmysqlclient_r.so.15 (0xb70a1000)
libicuuc.so.42 => /usr/lib/libicuuc.so.42 (0xb6f61000)
libicudata.so.42 => /usr/lib/libicudata.so.42 (0xb601a000)
libicui18n.so.42 => /usr/lib/libicui18n.so.42 (0xb5e6b000)
libcrypt.so.1 => /lib/i686/cmov/libcrypt.so.1 (0xb5e39000)
libnsl.so.1 => /lib/i686/cmov/libnsl.so.1 (0xb5e22000)
Run Code Online (Sandbox Code Playgroud)
这些库通过其中提到的路径中的soname(例如libboost_filesystem-mt.so.1.38.0)进行搜索/etc/ld.so.conf,LD_LIBRARY_PATH或者rpath在二进制本身中进行设置.
如果ldd无法找到它会是什么样子
libicuuc.so.42 => not found
Run Code Online (Sandbox Code Playgroud)
在这种情况下,请考虑使用上述方法之一来提供正确的搜索路径.
ldd 由于某种原因,当它无法加载库时会发出警告.
$ ldd v8test
./v8test: error while loading shared libraries: /home/dmitry/a/liba.so.2: invalid ELF header
Run Code Online (Sandbox Code Playgroud)
当然,它无法保护您免受库本身的错误.事实上,您的应用程序可能依赖于库A和B,两者都取决于某些库C上的不兼容版本.在这种情况下,您的程序很有可能崩溃(除非库C没有符号版本控制) - ldd不是要警告你,但你应该能够在输出中看到它.
还要检查ldd或动态链接器的一些选项.
| 归档时间: |
|
| 查看次数: |
3956 次 |
| 最近记录: |