1 src : = $(shell ls *.c)
2 objs : = $(patsubst %.c, %.o, $(src))
3 test : $(objs)
4 gcc -o $@ $^
5 %.o : %.c
6 gcc -c -o $@ $<
7 cleam :
8 rm -f test *.o
注:在Makefile编写规则中,“$@”表示规则的目标文件名,“$^”表示所有不重复的依赖文件名,“$<”表示第一个依赖文件名。
假设现在目录下有main.c, Makefile, sub.c, sub.h四个文件,
第1行:src变量的值为main.c和sub.c;
第2行:objs变量的值为main.o和sub.o;
第5、6行:用来生成main.o和sub.o的规则;
对main.o来说就是:
main.o: main.c
gcc -c -o main.o main.c
对sub.o来说就是:
sub.o: sub.c
gcc -c -o sub.o sub.c
第3行:即test:main.o sub.o;
第4行:根据第6行生成的main.o和sub.o文件来生成可执行文件test;
第7、8行:清理main.o和sub.o文件。