【Makefile】01-前置知识
此系列文章是基于陈皓《跟我一起写Makefile》的总结。
1 Makefile简介
在初学C语言的时候,往往是使用Visual Stdio、Codeblock等IDE。写完代码,点击编译按钮,就会自动生成可执行文件。这样的好处是操作方便,可以将精力集中在语言学习本身。但IDE隐藏了编译过程的细节,在学习深入后,应当探究其原理。此外,如果在Linux环境下开发,就必须要学会写Makefile。可以说,会不会写Makefile,可以说明开发者是否具备完成大型工程的能力。
Makefile建立了整个工程的编译规则。大型工程中,源文件数量十分庞大,并且根据功能模块放在多个目录中。Makefile定义一系列规则,指定文件的编译顺序。此外,Makefile就像shell脚本,可以执行操作系统的命令。所以也可以进行更复杂的功能操作。
尽管目录和文件庞杂,使用Makefile,即可做到“自动化编译”。写好Makefile后,只要执行make命令,整个工程就会自动编译。make是一个命令工具,用于解释Makefile中的指令。
不同厂商的make不尽相同,但万变不离其宗,都是在“文件依赖性”上做文章。GNU的make应用最广泛,我们就以此为例来学习。
2 程序的编译和链接
从源文件到可执行文件,其实分为几个阶段。要学习Makefile,首先要对这个过程建立了解。
2.1 编译(compile)
在编译过程中,首先将源文件编译成中间目标文件(Object File),在Windows下是.obj文件,Linux下是.o文件。将源文件转换成中间目标文件的过程就叫编译。
编译时,编译器要检测语法正确、函数与变量的声明正确。只要语法正确,编译器就可以编译出中间目标文件。即使函数未被声明,编译器也会生成中间目标文件,只是会给出警告信息。
一般而言,每个源文件对应一个中间目标文件。
2.2 链接(link)
将编译阶段生成的中间目标文件合成执行文件的动作叫做链接。
链接时,主要是链接函数和全局变量。链接器并不关心函数所在的源文件,只在意函数的中间目标文件。链接器会在所有中间目标文件中查找函数的实现。如果找不到,就会报出链接错误码(Linker Error)。在VC中,一般是Link 2001错误。
大型工程中,源文件的数量非常多。相应地,编译生成的中间目标文件也非常多。链接时要明显地指出中间目标文件名,非常不方便。为了解决这个问题,就要将中间目标文件打包。在Windows下,称为Library File,后缀为.lib。在Linux下,称为Archive File,后缀为.a。