项目构建工具:make/Makefile
Makefile
- 是一个普通的文本文件,文件中记录的是一个项目的所有构建规则
make
- 是一个解释程序,在执行 make 命令的时候,会到当前目录里下寻找 Makefile 文件,然后对 Makefile 中记录的构建规则进行逐行解释执行,最终完成整个项目的构建。
Makefile 编写规则
- 目标对象:依赖对象
- [Tab]为了生成目标对象所执行的命令语句
预定义变量
- $^ : 所有的依赖对象内容
- [email protected]:目标对象内容
- $<:依赖对象中的第一个
关键字 wildcard
- 当一个项目中有多个依赖对象(依赖对象为 .c 文件)时,为了解决在 Makefile 编写时,减少书写依赖对象的麻烦,于是就有了 wildcard 关键字。
关键字 patsubst
- 当一个项目中有多个依赖对象(依赖对象为 .o 文件)时,为了解决在 Makefile 编写时,减少书写依赖对象的麻烦,于是就有了 wildcard 关键字。
为了减少代码量,我们还可以用上通配符:
项目文件清理与申明伪对象
-
现在Makefile 里面的代码如下:
-
工程是需要被清理的 ,在我们 make 之后会有一大堆的 .o 文件,这些东西是需要被清理的。但是,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示的 make 执行。
存在一个问题是,如果当前目录下有 clear 文件,这时候显示执行 make clear 时,会t提示说{make: “clear”是最新的.}。
为了解决这个问题,一般我们这种 clear 的目标文件,我们将它设置为伪目标,用 .PHONY 修饰。伪对象的特征是:不管目标对象是否为最新,每次都要重新生成。
make 的解释执行规则
- 从上往下找到第一个目标对象,生成后,则退出。make会一层又一层地去找文件的依赖关系,直到终编译出第一个目标文件。在找寻的过程中,如果出现错误,比如后被依赖的文件找不到,那么make就会直接退出。