Makefile
- 是一个普通的文本文件,文件中记录的是一个项目的所有构建规则
make
- 是一个解释程序,在执行 make 命令的时候,会到当前目录里下寻找 Makefile 文件,然后对 Makefile 中记录的构建规则进行逐行解释执行,最终完成整个项目的构建。
Makefile 编写规则
- 目标对象:依赖对象
- [Tab]为了生成目标对象所执行的命令语句

预定义变量
- $^ : 所有的依赖对象内容
- $@:目标对象内容
- $<:依赖对象中的第一个

关键字 wildcard
- 当一个项目中有多个依赖对象(依赖对象为 .c 文件)时,为了解决在 Makefile 编写时,减少书写依赖对象的麻烦,于是就有了 wildcard 关键字。

关键字 patsubst
- 当一个项目中有多个依赖对象(依赖对象为 .o 文件)时,为了解决在 Makefile 编写时,减少书写依赖对象的麻烦,于是就有了 wildcard 关键字。

为了减少代码量,我们还可以用上通配符:

项目文件清理与申明伪对象
-
现在Makefile 里面的代码如下:

-
工程是需要被清理的 ,在我们 make 之后会有一大堆的 .o 文件,这些东西是需要被清理的。但是,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示的 make 执行。

存在一个问题是,如果当前目录下有 clear 文件,这时候显示执行 make clear 时,会提示说{make: “clear”是最新的.}。

为了解决这个问题,一般我们这种 clear 的目标文件,我们将它设置为伪目标,用 .PHONY 修饰。伪对象的特征是:不管目标对象是否为最新,每次都要重新生成。

make 的解释执行规则
- 从上往下找到第一个目标对象,生成后,则退出。make会一层又一层地去找文件的依赖关系,直到终编译出第一个目标文件。在找寻的过程中,如果出现错误,比如后被依赖的文件找不到,那么make就会直接退出。

本文详细介绍了Makefile的原理及使用方法,包括Makefile的基本结构、目标对象与依赖对象的概念,以及如何通过预定义变量和关键字如wildcard、patsubst等优化构建过程。同时,还讲解了如何清理项目文件并声明伪对象,以及make命令的执行规则。
955

被折叠的 条评论
为什么被折叠?



