2023学习日志

2023-06-08 21:57:08 浏览数 (3)

Makefile

Makefile基本规则

代码语言:text复制
target ……:prerequisites ……
recipe
……

target

可以是需要生成的目标文件可执行文件或一个标签

prerequisites

是生成该target所依赖的文件或者其他target

recipe

是生成该target所需要的任意shell命令(真正执行的部分)

当prerequisites 被更新时,运行make命令,则会重新运行recipe中对应的shell命令

示例

代码语言:text复制
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命令时,将会根据文件的依赖关系,逐步生成targetprerequisites,再运行target对应的recipe

clean

值得注意的是,代码中的clean并非可执行文件目标文件,而是一个动作,类似于一个lable,在make时不会自动执行,需要显式输入make clean才能运行该target对应的recipe

此外,clean 更加规范的写法是,

代码语言:text复制
.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命令出错时继续运行,删除其他文件

makefile中使用变量

示例

代码语言:text复制
objects = main.o kbd.o command.o display.o 
    insert.o search.o files.o utils.o

edit : $(objects)
    cc -o edit $(objects)

make自动推导

示例

代码语言:text复制
main.o : defs.h

make会自动将与'.o'文件同名的'.c'文件加入依赖中

包含其他makefile

示例

代码语言:text复制
include foo.make *.mk $(bar)

可以使用include命令将其他makefile引入makefile中,include命令会将指定makefile文件插入到include命令的位置,因此需要注意include命令的位置

通配符

可以使用‘*、?、 ~’三个通配符

文件搜寻

示例

代码语言:text复制
VPATH = src:../headers
vpath %.h ../headers

可以使用特殊变量 VPATHvpath关键字来设置搜索目录

多目标与静态模式

比较复杂,还需要复习

自动生成依赖性

通过recipe自动生成文件的依赖关系,依赖关系放到对应的.d文件中

0 人点赞