makefile最基本的规则:
target ... : prerequisites ...
command
...
...
分析:
target也就是一个目标文件,可以是Object File,也可以是执行文件。还可以是一个标签(Label),对于标签这种特性,在后续的“伪目标”章节中会有叙述。(引用别人话)
prerequisites就是,要生成那个target所需要的文件或是目标。
command也就是make需要执行的命令。(任意的Shell命令)
一段很常见的片段:
如果编写一个规则,并不产生目标文件,则其命令在每次make 该目标时都执行。例如:
clean:
rm *.o temp
因为"rm"命令并不产生"clean"文件,则每次执行"make clean"的时候,该命令都会执行。但无论怎么说吧,假设目录中有个clean文件,但因为clean不依赖任何文件,所以不需要重新生成clean目标,这时rm *.o 就不会被执行了,怎么解决呢,看下面的.PHONY.
举例:
.PHONY : clean
clean :
rm *.o
makefile有个规则:.PHONY是一个为目标,其后依赖的文件永远都需要更新。(我们就把clean当成一个目标,只是它不依赖任何文件)
因为clean这个目标每次都需要重新生成,所以rm *.o每次都会执行。
另一端很常见的代码片段:
all : prog1 prog2 prog3
.PHONY : all
prog1 : prog1.o utils.o
cc -o prog1 prog1.o utils.o
prog2 : prog2.o
cc -o prog2 prog2.o
prog3 : prog3.o sort.o utils.o
cc -o prog3 prog3.o sort.o utils.o