make是如何判定什么时候需要编译什么时候不需要编译的:
Makefile的格式如下:
targets ... : prerequisites ...
command
make执行时会比较targets(目标文件)和prerequisites(依赖文件)文件的修改日期,如果prerequisites中有文件的修改日期比targets中文件的日期新,或者target不存在时,make才会执行后续的命令(command)
make是如何工作的:
make在执行过程中会一层又一层的去找文件的依赖关系,直到最终编译出一个第一个目标文件。在找寻的过程中如果出现错误,比如最后被依赖的文件未找到,则make会直接退出,并报错。
Makefile的隐含规则:
make可以自动推导文件以及文件依赖关系后面的命令。
例如:只要make看到一个.o文件,他就会自动的把对应的.c文件加在依赖关系中,如果make找到一个main.o,那么就会自动推导出main.c是main.o的依赖文件,并且cc -c main.c也会被推导出来。
清空目标文件:
正常示例:
clean:
rm target main.o
更为稳健的做法:
.PHONY : clean
clean:
-rm target main.o
.PHONY的意思表示clean是一个“伪目标”,rm前面的一个减号的作用是忽略rm过程中出现的问题,继续做后面的事情。clean的规则不要放在文件的开头,否则make的默认目标就会变成clean,因此clean需要放在文件的后面。
变量的定义:
在Makefile中又是会定义一系列的变量,变量一般都是字符串,类似C语言中的宏定义,当Makefile被执行时,其中的变量都会被替换到相应的引用位置上。
#定义变量
objects = main.o
#使用变量,使用方式:$()
main : $(objects)
cc -o main $(objects)