可执行二进制文件的形成过程与简单调试

1) 预处理:主要对源码预编译语句(如宏定义define)和文件包含进行处理。即对宏指令替换和包含文件放置到需要编译的文件中,完成后会生成完整的C程序源文件。

2) 编译:对预处理以后文件进行编译,生成.s后缀的汇编语言文件,即该文件里是汇编语言的代码,汇编是一种更底层的语言,直接对硬盘进行操作。

3) 汇编:对汇编语言文件进行汇编,主要调用汇编处理程序来完成汇编,汇编是生成二进制机器代码的过程,汇编后的文件以.o结尾,称为目标文件。

4) 链接:将多个由汇编生成的目标文件以及引用的库文件进行模块链接,生成一个完整的可执行文件,链接时,所有目标文件被安排在可执行程序的适当位置,同时程序调用的库函数也从各自所在的函数库链接到程序中。

 

下面演示C语言代码 如何转变成 可执行的二进制文件:

假如现在有段C语言源代码如下

 

对其进行预处理,处理后的文件如下图所示

gcc -E -o a.cxx a.c

 

 生成汇编代码

gcc -S -o a.s a.c

 

 

生成目标文件

gcc -c -o a.o a.c

 

链接生成可执行文件

gcc a.c -o a.out

 

最后一个可执行文件就生成了

 

下面是gdb调试程序基本使用

 

 

写一个简单的c语言程序测试下

 

 

生成debug文件

gcc -g -o a.debug hello.c

 

运行gdb,然后载入调试文件a.debug,list 查看源代码

 

break 设置断点,即运行到第几行,让程序暂停一下

 

info breakpoint 查看断点,删除断点用delete + Num

 

run 运行程序,如下图程序会在断点处暂停

 

 

输入next 让程序继续运行一行,输入continue 让程序运行到下一个断点为止

 

在断点处可以打印或者操作变量,对排除bug非常有用,退出则按q键即可

其他高级的用法可以去查阅相关资料,这里就不一一细说了。

 

posted @ 2017-08-31 21:08  Khazix  阅读(4613)  评论(0编辑  收藏  举报