标签:
下面以linux x86 下的程序来说明一个源程序是怎样变成一个可执行的二进制文件的。下面是我由一个交换数组中两个元素的值得简单程序来说明
main.c源文件的代码,和swap.c源文件代码分别如下:
1 #include<stdio.h> 2 #define SIZE 2 3 int buf[SIZE]={1,2}; 4 void swap(); 5 int main(){ 6 printf("before swap buf[0]=%d ,buf[1]=%d\n",buf[0],buf[1]); 7 swap(); 8 printf("after swap buf[0]=%d ,buf[1]=%d\n",buf[0],buf[1]); 9 }
extern int buf[]; void swap() { int temp; temp=buf[0]; buf[0]=buf[1] buf[1]=temp; }
通过下面这条命令,就产生了一个可执行二进制文件swap
》gcc mian.c swap.c -o swap
那么这条命令是么样把源程序变成可执行程序的呢?
步骤如下:
1、驱动程序首先调用C预处理器(CPP)把源文件翻译成一个ASCII中间文件mian.i,预处理器会把#include所包含的内容都插入到声明的位置,并且做宏替换,把main.c 文件的第3行 的SIZE替换成2(注意这里只是做简单的文本替换)。
2、接下来驱动程序的C编译器将main.i翻译成汇编语言程序main.s
3、然后驱动程序的汇编器将汇编语言程序main.s 翻译成可重定位的二进制文件main.o
4、最后运行链接器将main.o 与swap.o 以及一些必要的系统目标文件(比如你将调用的printf函数就是printf.o)连接起来变成一个可执行的二进制文件。
标签:
原文地址:http://www.cnblogs.com/yinhf123/p/4638354.html