一个工程中的源文件不计其数,按其功能、类型、模块放在若干个目录中,makefile定义了一系列的规则来指定,那些文件需要先编译,那些文件需要后编译,以及那些文件需要重新编译,甚至更复杂的功能操作。
makefile的优势是“自动化编译”,一旦写好,只需一个make指令,整个工程自动编译,极大地提高了软件开发效率。make是一个解释makefile中指令的一个命令工具。
1、特殊的符号
#:注释符
@:隐藏,加在命令前,不打印命令
2、变量的赋值
递归赋值:
A = I love $(B)
B = you
直接赋值:
A := I love $(B)
B := you
条件赋值:
A ?= I love $(B)
B ?= you
3、特殊的环境变量
3.1、^ @: 分别针对依赖文件和目标文件
main: a.o b.o main.o
$^ —> a.o b.o main.o
$@ —> main
3.2、 VPATH
作用:告诉make工具可以去指定路径下寻找源文件
举例 :VPATH = ./dir1:./dir2:./dir3
4、规则
4.1、普通规则
OBJ = a.o b.o main.o
main : $(OBJ)
gcc $^ -o $@
a.o:a.c
gcc -c $^
b.o:b.c
gcc -c $^
main.o:main.c
gcc -c $^
4.2、隐式规则
OBJ = a.o b.o main.o
main: $(OBJ)
gcc $^ -o $@
4.3、静态规则
OBJ = a.o b.o main.o
IMAGE = main
CFLAG = -I ./inc
$(IMAGE): $(OBJ)
gcc $^ -o $@
%.o:%.c
gcc -c $^ $(CFLAG)
4.4、最终版本
伪目标:不用生成目标文件的指令
应用:给makefile中添加一个rm的功能
.PHONY:clean
clean:
rm $(IMAGE) $(OBJ)
这样执行"make clean"会无视"clean"文件存在与否。
应用举例:
OBJ = a.o b.o main.o
IMAGE = main
CFLAG = -I ./inc
VPATH = ./src:./
$(IMAGE): $(OBJ)
gcc $^ -o $@
%.o:%.c
gcc -c $^ $(CFLAG)
clean:
rm $(IMAGE) $(OBJ)
.PHONY:clean
5、高级应用
5.1、利用通配符把.C文件列表转换成.O文件列表
a.c b.c main.c 转换成 a.o b.o main.o
SRC = a.c b.c main.c
OBJ = $(SRC:%.c=%.o)
5.2、变量的自加
VPATH = ./dir1:./dir2
VPATH += :./dir3
all:
echo $(VPATH)
5.3、利用伪目标生成多个最终目标文件
伪目标特点:假如伪目标有依赖目标,那么不管有几个都可作为最终目标文件来生成
SRC = a.c b.c main.c
SRC2 = a.c b.c primath.c
OBJ = $(SRC:%.c=%.o)
OBJ2 = $(SRC2:%.c=%.o)
IMAGE1 = main
IMAGE2 = primath
CFLAG = -I ./inc
VPATH = ./src:./:./pri
.PHONY:TMP
TMP:$(IMAGE1) $(IMAGE2)
$(IMAGE2):$(OBJ2)
gcc $^ -o $@
$(IMAGE1): $(OBJ)
gcc $^ -o $@
%.o:%.c
gcc -c $^ $(CFLAG)
clean:
rm *.o $(IMAGE1) $(IMAGE2)
.PHONY:clean