makefile文件模板介绍

时间:2023-03-09 22:50:56
makefile文件模板介绍

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文件。