use*_*342 18
它取决于"检测库依赖"的确切含义.
该ldd命令适用于共享库,而不仅仅适用于可执行文件.它将显示构建库时声明的共享库的依赖关系:
$ ldd /usr/lib/libgtk-3.so
linux-vdso.so.1 (0x00007ffff8fff000)
libgdk-3.so.0 => /usr/lib/libgdk-3.so.0 (0x00007f43fcf47000)
libgmodule-2.0.so.0 => /usr/lib/libgmodule-2.0.so.0 (0x00007f43fcd43000)
libpangocairo-1.0.so.0 => /usr/lib/libpangocairo-1.0.so.0 (0x00007f43fcb36000)
libX11.so.6 => /usr/lib/libX11.so.6 (0x00007f43fc7fc000)
...
Run Code Online (Sandbox Code Playgroud)
库可以具有未定义的符号,这些符号是通过链接未声明为依赖项的其他库而获得的.您可以使用objdump -T或nm -D显示动态符号 - 未定义的符号(应该来自其他库的符号)将显示为*UND*:
$ objdump -T /usr/lib/libgtk-3.so | head
/usr/lib/libgtk-3.so: file format elf64-x86-64
DYNAMIC SYMBOL TABLE:
0000000000066e38 l d .init 0000000000000000 .init
0000000000000000 DF *UND* 0000000000000000 g_param_spec_object
0000000000000000 DF *UND* 0000000000000000 g_utf8_validate
0000000000000000 DF *UND* 0000000000000000 g_date_get_month
0000000000000000 DF *UND* 0000000000000000 g_bookmark_file_get_visited
0000000000000000 DF *UND* 0000000000000000 g_value_get_float
Run Code Online (Sandbox Code Playgroud)
从这些符号名称中,应该可以推断出未声明的库依赖项.
使用pkg-config或类似配置机制的库有时无法在构建时声明它们的依赖项,但是声明依赖项pkg-config,依赖库用户使用该工具来获取依赖项.pkg-config --libs将以编译器理解的格式列出依赖项:
$ pkg-config --libs gtk+-3.0
-lgtk-3 -lgdk-3 -latk-1.0 -lgio-2.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo-gobject -lpango-1.0 -lcairo -lgobject-2.0 -lglib-2.0
Run Code Online (Sandbox Code Playgroud)