1. 多目标
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
2.静态模式
objects = foo.o bar.o all: $(objects) $(objects): %.o: %.c $(CC) -c $(CFLAGS) $< -o $@
“%.o” 表明要所有以 “.o” 结尾的目标,也就是 “foo.o bar.o” ,也就是变量 $object 集合的模式。
依赖模式 “%.c” 则取模式 “%.o” 的 “%” ,也就是 “foo bar” ,并为其加下 “.c” 的后缀,于是,我们的依赖目标就是 “foo.c bar.c”
而命令中的 “$<” 和 “$@” 则是自动化变量, “$<” 表示所有的依赖目标集(也就是 “foo.c bar.c” ), “$@” 表示目标集(也就是 “foo.o bar.o” )
另一个例子, $(filter %.o,$(files))表示调用 Makefile 的 filter 函数,过滤 “$filter” 集,只要其中模式为 “%.o” 的内容:
files = foo.elc bar.o lose.o $(filter %.o,$(files)): %.o: %.c $(CC) -c $(CFLAGS) $< -o $@ $(filter %.elc,$(files)): %.elc: %.el emacs -f batch-byte-compile $<