在Linux下查看导入表的Dumpbin.exe替代工具

14

我不确定我的问题在 Linux 方面是否有意义。我正在寻找类似于 Visual Studio 工具包中的 dumpbin.exe 的工具。

基本上,我有一个已有的项目,其中包含一堆库和一个单独的可执行文件。我想弄清楚哪些库是真正需要的,以及每个库中的哪些函数。

由于该项目针对 ARM 设备,因此仅使用共享对象。

1个回答

17
也许你可以使用ldd和nm。ldd会告诉你需要哪些共享对象(在Windows中称为dll)。而nm则会显示符号信息。
示例运行命令:
$ ldd a
        linux-vdso.so.1 =>  (0x00007fffd1dff000)
        libc.so.6 => /lib/libc.so.6 (0x00007fcbc97d9000)
        /lib64/ld-linux-x86-64.so.2 (0x00007fcbc9b21000)
$ nm a
0000000000600e40 d _DYNAMIC
0000000000600fe8 d _GLOBAL_OFFSET_TABLE_
00000000004005b8 R _IO_stdin_used
                 w _Jv_RegisterClasses
0000000000601020 A __bss_start
0000000000601008 D __data_start
0000000000601010 D __dso_handle
                 w __gmon_start__
0000000000600e14 d __init_array_end
0000000000600e14 d __init_array_start
00000000004004d0 T __libc_csu_fini
00000000004004e0 T __libc_csu_init
                 U __libc_start_main@@GLIBC_2.2.5
0000000000601020 A _edata
0000000000601028 A _end
00000000004005a8 T _fini
00000000004003c0 T _init
0000000000400400 T _start
0000000000601008 W data_start
00000000004004b8 T main

编辑:忘记了objdump。例如:

$ objdump -f a

a:     file format elf64-x86-64
architecture: i386:x86-64, flags 0x00000112:
EXEC_P, HAS_SYMS, D_PAGED
start address 0x0000000000400400

使用 -x 选项可以显示所有的头信息(这会导致输出内容非常冗长,请自行尝试)。

1
使用ldd命令,我得到了“不是动态可执行文件”的错误。 - Eric
2
如果您收到此消息,则表示所涉及的文件不是动态链接,而是静态编译的(所有符号都在文件本身中编译,而不是在运行时使用任何共享对象)。 - marcelog

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接