A ferramenta padrão para listar símbolos é nm
: você pode usá-lo da seguinte maneira:
nm -gD yourLib.so
Se você quiser ver símbolos de uma biblioteca C ++, adicione a opção "-C" que desmantela os símbolos (é muito mais legível desmontada).
nm -gDC yourLib.so
Se o seu arquivo .so estiver no formato elfo, você terá duas opções:
Qualquer um objdump
( -C
também é útil para desmantelar C ++):
$ objdump -TC libz.so
libz.so: file format elf64-x86-64
DYNAMIC SYMBOL TABLE:
0000000000002010 l d .init 0000000000000000 .init
0000000000000000 DF *UND* 0000000000000000 GLIBC_2.2.5 free
0000000000000000 DF *UND* 0000000000000000 GLIBC_2.2.5 __errno_location
0000000000000000 w D *UND* 0000000000000000 _ITM_deregisterTMCloneTable
Ou use readelf
:
$ readelf -Ws libz.so
Symbol table '.dynsym' contains 112 entries:
Num: Value Size Type Bind Vis Ndx Name
0: 0000000000000000 0 NOTYPE LOCAL DEFAULT UND
1: 0000000000002010 0 SECTION LOCAL DEFAULT 10
2: 0000000000000000 0 FUNC GLOBAL DEFAULT UND free@GLIBC_2.2.5 (14)
3: 0000000000000000 0 FUNC GLOBAL DEFAULT UND __errno_location@GLIBC_2.2.5 (14)
4: 0000000000000000 0 NOTYPE WEAK DEFAULT UND _ITM_deregisterTMCloneTable
nm
não responde a algumas opções, como-D
e-g
(IIRC).