一: 翻译环境与运行环境
二:翻译环境
2.1 预处理
2.2 预编译
2.3 汇编
2.4链接
一:翻译环境与运行环境
翻译环境:
一开始,各个文件独立的进入到编译器中,先进行预处理,得到后缀为.i的中间文件,接着,进入到编译阶段,得到后缀为.s的中间文件。接着,就进入到汇编,得到以.o为后缀的目标文件,最后,进入到链接器,再与链接库相连接上,来得到可执行文件。
二:翻译环境
2-1 预处理:
预处理阶段主要是处理源文件中#开始的预编译指令,例如#include所包含的头文件,#define所定义的宏,还有一下会处理的操作
1.把#define删去,然后将定义的宏或是常量展开
2.把所包含的头文件展开,可以递归式的展开
3.对于注释都删除掉
4.添加行号与文件名作为标识
5.处理编译条件指令#if,#endif,#elif等
2-2 编译:
编译中包含了三个步骤,分别是词法分析,语法分析和语义分析
2-2-1 词法分析
其为对源码进行扫描后,把代码中的字符串分成一个个小的记号,例如array[index](index+4)*(2+3),词法分析就会把它切分为,array , [, index, ], (, index ,+,4, ) ,* ,( ,2 ,+ ,3 ,) 会切分为这几个记号,接着就进入到语法分析
2-2-2 语法分析
2-2-3 语义分析
就是看每一个部分的数据类型,以及每一个数据之间的运算是否是合理的,像上面那个例子与其对应的图,其中每个部分都是整型,因此得到的结果也是整型,所以这个语义是合理的,就不会报错。
2-3 汇编
就是把汇编代码转化为机器人可以读的懂得形式,就是转化为二进制形式
2-4 链接 把一堆代码链接在一起,生成可执行文件,前面在预处理等阶段中,文件都是单独执行的,并没有相互链接在一起,但如果在多个源文件中应用到有一个函数,而这个函数的定义是在一个头文件中,为了使得源文件中的代码可以执行,就会把其他源文件中的所用到的这个函数的地址进行修正,把真正的函数地址传递给他们,让他们在使用的时候,是可以找到头文件中的函数的。
今天的内容就分享到这里啦,希望大家能够对于我们的代码是如何运行起来的能有一定的了解。