make是一条命令,makefile是一个文件,两者搭配使用,完成项目的自动化构建
案例
其中,make在扫描makefile文件时,默认只会生成一个目标依赖关系,一般是第一个!否则要指明。
.PHONY
修饰的符号,代表 伪目标,总是可以执行。否则就可以执行一次(报错如下)
也可以这样写:
$@
表示目标文件,$^
表示文件列表
依赖关系
文件test,依赖test.o
test.o依赖test.s
test.s依赖test.i
test.i依赖test.c
原理
1、make会在当前工作目录下寻找名字叫做makefile
或者 Makefile
的文件
2、如果找到,会把文件中第一个目标文件(test)当作最终的目标文件。
3、如果test依赖的test.o文件不存在,make会在当前文件中找目标是test.o文件的依赖性,如果找到规则生成test.o
3、make会一层一层找文件的依赖关系,直到最终编译出第一个目标文件(类似堆栈过程)
4、如果找的时候出现错误,比如最后被依赖的文件找不到,make会直接退出,报错;对定义的命令错误,or编译失败,make不理。
5、make只管文件的依赖性,如果找到依赖关系,冒号后面的文件还是不在,那make就不工作啦~
项目清理
像clean这种,没有和第一个目标文件直接或者间接关联,那么它后面定义的命令就不会自动执行。但可以显示要make执行,make clean
,来清除所有的目标文件,方便我们重新编译。
一般clean的目标文件,将它设置成伪目标,.PHONY
修饰,伪目标总是被执行的~