在程序编译过程中,Makefile的主要作用就是:构建生成可执行文件的依赖关系树。一个可执行文件需要哪些源文件、哪些库,我们都可以在Makefile里指定。在程序编译阶段,make工具会首先解析这个Makefile,根据Makefile里的指定,构建出编译可执行文件所需要的完整依赖关系。
根据这个依赖关系,make工具接下来就可以分别去编译需要的文件;通过时间戳,可以动态识别哪些是新添加的文件,哪些是已经编译过的文件,哪些文件做了新的修改,这样就不用每次都重新编译了,只编译那些新修改或新添加的源文件就可以了,大大提升了编译的效率。
那Makefile是如何构建可执行文件编译所依赖的关系树的呢?很简单,通过规则。
1.规则
规则是Makefile的基本组成单元。一个规则通常由目标、目标依赖和命令三部分构成:
目标:目标依赖
命令
a.out:hello.c
gcc -o a.out hello.c
如上所示,a.out就是我们要生成的目标,目标一般是一个可执行文件。目标依赖是指生成这个可执行文件所依赖的源文件,如 hello.c。而命令则是如何将这些目标依赖生成对应的目标,一般是gcc命令、链接命令、objcopy命令,一些shell命令等。命令必须使用 tab 键进行缩进,否则Makefile就会报错。
一个规则中的三个部分并不是都必须要有的。一个Makefile文件中可能包含多个规则,有的规则可能无目标依赖,仅仅是为了实现某