tips of building & debug execute files

来源:互联网 发布:波动率交易知乎 编辑:程序博客网 时间:2024/05/16 11:35

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. 未完待续.......