Makefile基本规则
target ……:prerequisites ……
recipe
……
可以是需要生成的目标文件、可执行文件或一个标签
是生成该target所依赖的文件或者其他target
是生成该target所需要的任意shell命令(真正执行的部分)
当prerequisites 被更新时,运行make命令,则会重新运行recipe中对应的shell命令
示例
edit : main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
cc -o edit main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
main.o : main.c defs.h
cc -c main.c
kbd.o : kbd.c defs.h command.h
cc -c kbd.c
command.o : command.c defs.h command.h
cc -c command.c
display.o : display.c defs.h buffer.h
cc -c display.c
insert.o : insert.c defs.h buffer.h
cc -c insert.c
search.o : search.c defs.h buffer.h
cc -c search.c
files.o : files.c defs.h buffer.h command.h
cc -c files.c
utils.o : utils.c defs.h
cc -c utils.c
clean :
rm edit main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
代码中,edit为待生成的可执行文件,其依赖与main.o、kbd.o等一堆‘.o’文件,而这些‘.o'文件又各种依赖于其他文件。因此,运行make命令时,将会根据文件的依赖关系,逐步生成target的prerequisites,再运行target对应的recipe
值得注意的是,代码中的clean并非可执行文件或目标文件,而是一个动作,类似于一个lable,在make时不会自动执行,需要显式输入make clean才能运行该target对应的recipe
此外,clean 更加规范的写法是,
.PHONY: clean
clean:
-rm edit main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
.PHONY表示clean为伪标签,而-rm表示当shell命令出错时继续运行,删除其他文件
示例
objects = main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
edit : $(objects)
cc -o edit $(objects)
示例
main.o : defs.h
make会自动将与'.o'文件同名的'.c'文件加入依赖中
示例
include foo.make *.mk $(bar)
可以使用include命令将其他makefile引入makefile中,include命令会将指定makefile文件插入到include命令的位置,因此需要注意include命令的位置
可以使用‘*、?、 ~’三个通配符
示例
VPATH = src:../headers
vpath %.h ../headers
可以使用特殊变量 VPATH或vpath关键字来设置搜索目录
比较复杂,还需要复习
通过recipe自动生成文件的依赖关系,依赖关系放到对应的.d文件中
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。