1、总体规则
target ... : prerequisites ...
command
...
定义好依赖关系后,后续的那一行定义了如何生成目标文件的操作系统命令。
2、可以定义变量
只要make看到一个[.o]文件,它就会自动的把[.c]文件加在依赖关系中
objects = main.o kbd.o command.o display.o /
insert.o search.o files.o utils.o
使用$(object)来替代这些.O文件
3、MAKEFILE自动推导功能
main.o : defs.h等价于main.o : defs.h main.c
4、清空目标文件
clean :
-rm edit $(objects)
小横线表示出错了也不用管;
5、注意
Makefile中的命令,必须要以[Tab]键开始。
6、引用其它MAKEFILE
include <filename>
7、在规则中使用通配符
“~/test”,这就表示当前用户的$HOME目录下的test目录。
“*”,“?”和“[...]”。
8、文件搜寻
VPATH = src:../headers,“src”和“../headers”,make会按照这个顺序进行搜索。目录由“冒号”分隔。
9、一个例子:
objects = foo.o bar.o
all: $(objects)
$(objects): %.o: %.c
$(CC) -c $(CFLAGS) $< -o $@
上面的例子中,指明了我们的目标从$object中获取,“%.o”表明要所有以“.o”结尾的目标,也就是“foo.o bar.o”,也就是变量$object集合的模式,而依赖模式“%.c”则取模式“%.o”的“%”,也就是“foo bar”,并为其加下“.c”的后缀,于是,我们的依赖目标就是“foo.c bar.c”。而命令中的“$<”和“$@”则是自动化变量,“$<”表示所有的依赖目标集(也就是“foo.c bar.c”),“$@”表示目标集(也就是oo.o bar.o”)。