之前对于编译期和运行期的理解都停留于书面,只是浅显的知道多态发生于运行期之类的知识点,现在上网查找下相关资料,做下知识点汇总
1 编译系统
在Unix系统上,从源文件到可执行文件,是由编译器驱动程序完成的。对于GCC编译器驱动程序来编译hello.c源文件,首先读取源程序文件,然后把它翻译成可执行文件hello。这个翻译过程由四个阶段完成:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-B9fGaUB3-1651916251981)(C:\Users\PrinceAlLHH\AppData\Roaming\Typora\typora-user-images\image-20220422172220677.png)]
执行以上四个阶段的程序(预处理器、编译器、汇编器以及链接器)一起构成了编译系统。
1.1 预处理阶段
预处理器负责展开宏以及头文件,然后替换条件编译,最后删除注释、空行、空白。那这里条件编译是什么呢?见下图:
预处理阶段则把hello.c翻译成hello.i。
1.2 编译阶段
编译阶段其实就是在检查语法规范,该阶段是最消耗时间和系统资源的阶段。这个阶段中,编译器负责将文本文件hello.i翻译成文本文件hello.s,这个.s文件就包含一个汇编语言程序,然后该程序将会输入至汇编器中进行汇编。
1.3 汇编阶段
该阶段则是使用汇编器,将汇编语言程序翻译成机器语言指令,然后把这些指令打包成一种叫做可重定位目标程序的格式,并将结果保存在目标文件hello.o中。hello.o是一个二进制文件。
1.4 链接阶段
链接阶段则是将当前工程中的多个目标文件,用链接器以某种方式合并起来,然后就得到了可执行文件hello。该文件可以被加载到内存当中,由系统执行。
2 编译期
其实,编译期就是第一节编译系统中讲到的这四个阶段。编译期是指把你的源程序交给编译器编译的过程,最终目的是得到目标文件,链接后生成可执行文件(预处理、编译、汇编和连接)。编译期有如下注意的地方:
-
**编译期分配内存,就是用静态或全局数组。**这是在编译的时候确定的。
-
编译期内存错误,就是比如某个数据段DATA段或者CODE段等等,超过跑这个程序的目标机的存储器的限制。比如DOS下,DATA段不能超过64K吧。
3 运行期
运行期指的是我们将可执行文件交给操作系统(输入文件名,回车)执行、直到程序执行结束的这个时期。执行的目的是为了实现程序的功能 。运行期有如下注意的地方:
- 运行期分配内存,就是用new()之类的函数,在堆上分配内存。
- 运行期内存错误,就是运行的时候发生的,比如申请不到内存,内存越界访问,等等。
参考文献:
https://blog.csdn.net/m0_37264397/article/details/76697237
log.csdn.net/m0_37264397/article/details/76697237
《深入理解计算机系统(第三版)》