1. 在linux下查看某个二进制可执行程序依赖的库文件(so文件),用ldd命令即可。
2. nm 可以查看 execute file 的 symbal
3. objdump 也可以查看execute的symbal
引用:http://www.51testing.com/?uid-291148-action-viewspace-itemid-213676
objdump -x obj 以某种分类信息的形式把目标文件的数据组织(被分为几大块)输出 <可查到该文件的所有动态库>
objdump -t obj 输出目标文件的符号表()
objdump -h obj 输出目标文件的所有段概括()
objdump -j .text/.data -S obj 输出指定段的信息,大概就是反汇编源代码把
objdump -S obj C语言与汇编语言同时显示
1) 通过编译器直接从源文件生成, 如gcc -S
2) 对目标代码反汇编, 一种是静态反汇编, 就是使用objdump
3) 另外一种就是对运行时的代码反汇编, 一般通过gdb
4. 链接时,指定使用静态链接库 -static
5. 连接时,指定使用动态连接库 -shared
6. makefile
addsuffix : $(addsuffix .o, $(SRC_NAME))
wildcard: $(wildcard *.cpp) $(wildcard *.cpp ./src)
patsubst: $(patsubst %.cpp, %, $(wildcard *.cpp)) $(patsubst %.c, %, $(wildcard *.c))
7. using corefile
1) gdb ./a.out --core core.1024
2) gdb ./a.out
gdb> core-file core.1024
3) bt ---> print all call stack trace
4) frame n ---> 进入对应的调用层次,之后可以list代码, p 一些信息
8. 这篇文章关于静态库和动态库的编译link,很详细,而且还提到了常碰到的问题。
http://sourceforge.net/apps/trac/elpi/wiki/AlpWritingAndUsingLibraries
0. 未完待续.......