1、规则:
目标:依赖1 依赖2
命令
*说明:使用命令,将依赖生成目标
注意:目标顶格写,命令前有一个TAB键,不能使用空格代替
命令执行条件:
a. “依赖”文件 比 “目标”文件 新
b. 没有“目标”这个文件
满足上述条件之一,命名就会执行
2、简单的Makefile
在源文件下新建一个Makefile文件,内容为:
test:a.c b.c a.h
gcc -o test a.c b.c
注意:第二行前有一个TAB键,不是空格
第一行:test表示执行make后生成的目标文件,a.c b.c a.h表示目标文件test依赖a.c b.c a.h这三个文件产生
第二行:使用这条命令来生成目标文件test
那么命令gcc -o test a.c b.c什么时候被执行呢?在前面我们已经讲过
命令执行条件:
a. “依赖”文件 比 “目标”文件 新
b. 没有“目标”这个文件
当我们第一次编译时,并没有目标文件test,满足条件b,所以命令得到执行
当我们第一次执行make时,会编译生成test,当再次执行make时,编译器会提示目标文件已经是最新的,即没有使用gcc -o test a.c b.c编译,为什么呢?因为有“目标”文件,且没有“依赖“比”目标文件”新,即上面的两个条件都不满足,所以命令不会执行。那么如何让命令再次执行?
方法1:删除目标文件test
方法2:修改a.c b.c a.h会使依赖文件比目标文件新
3、每个Makefile中都应该写一个清空目标文件(.o和执行文件)的规则,这不仅便于重编译,也很利于保持文件的清洁。
.PHONY : clean
clean :
-rm edit $(objects)