1.make/Makefile简介
1.1Makefile
Makefile是一个文本文件,用于记录一个项目的构建规则
1.2make
make是一个Makefile解释程序,找到当前目录下的Makefile然后逐行解释,执行指令完成项目的构建。
2.Makefile编写规则★
目标对象:依赖对象
[tab]要执行的指令
示例:
在Makefile中写入以下内容:
2.1伪对象
因为非依赖文件的修改,不会引起目标对象的重新生成,所有引入了伪对象,即被.PHONY:修饰的目标,总是被执行的。
伪对象声明:
.PHONY:伪对象
功能:
表示当前的目标对象,并不是一个需要实际生成的实体目标对象,根本目的是为了解除目标对象与实体之间的关系。常用于项目清理的clean对象。
示例:
此时尝试重复生成test,会显示已是最新,不会重新执行:
将其声明为伪对象,再次尝试:
每次都会重新执行。
2.2预定义变量
$^
表示所有的依赖对象。
$@
表示目标对象。
$<
表示所有依赖对象中的第一个。
示例:
gcc $^ -o $@ 就会被解释为 gcc test.c -o test
3.make解释规则★
· make会根据目标对象和依赖对象的最后一次修改时间来进行判断,判断目标对象是否需要重新生成。
· make后面跟上目标对象名称,表示在Makefile中寻找对应的目标对象生成规则,生成指定目标对象。
· make找到Makefile中的第一个目标对象及生成规则,进行指令执行,生成后就退出;这意味着Makefile中就算有多个目标对象,也只生成第一个。
· make虽然只生成第一个目标对象,但是如果它的依赖对象不存在,它会递归向下寻找依赖对象依赖对象的生成规则,先将依赖对象生成,然后再去生成目标对象。