Makefile 的引入及规则
gcc -o file file.c
预处理-编译-汇编-链接 file.i -> file.s -> file.o -> file 缺点是对所有的文件再处理一次,在文件非常多时耗时非常长。应该分别编译,最后链接。
gcc -c -o a.o a.c
gcc -c -o b.o b.c
gcc -o test a.o b.o
如何判断哪些文件被修改了?通过比较a.c(b.c,a.o b.o)与a.o(b.o,test)的文件最后修改时间。
Makefile基本的语法规则
目标文件:依赖文件1 依赖文件2 ....
[TAB]——命令
当依赖比目标新,执行命令
test:a.o b.o
gcc -o test a.o b.o
a.o:a.c
gcc -c -o a.o a.c
b.o:b.c
gcc -c -o b.o b.c
a.通配符:%.o b.假想目标:.PHONY c.即时变量、延时变量,export
a.通配符的用法举例
test:a.o b.o
gcc -o test a.o b.o
%.o:%.c
gcc -c -o $@ $<
test:a.o b.o c.c
gcc -o test $^
%.o:%.c
gcc -c -o $@ $<
$@ 表示目标
$< 表示第一个依赖文件
$^ 表示所有的依赖文件
b.假想目标
test:a.o b.o c.c
gcc -o test $^
%.o:%.c
gcc -c -o $@ $<
clean:
rm *.o test
.PHONY:clean/*假想目标*/
make [目标名] 若无目标,执行第一个
c.即时变量,延时变量
简单变量(即时变量):A := xxx #A的值即可确定 B = xxx #B的值使用到时才确定
A := abc
B = 123
all:
@echo $(A)
@echo $(B)
:= #即时变量
= #延时变量
?= #延时变量,如果是第一次定义才有效,如果在前面该变量已定义则忽略这句
+= #附加,它是即时变量还是延时变量取决于前面的定义
Makefile函数
a. $(foreach var,list,text)
b. $(filter pattern...,text) 在text中取出符合pattern格式的值
$(filter-out pattern...,text) 在text中取出不符合pattern格式的值
c. $(wildcard pattern) pattern定义了文件名的格式,wildcard取出其中存在的文件
d. (var)) #从列表中取出每一个值,如果符合pattern则替换为replacement
Linux Makefile 生成 *.d 依赖文件及 gcc -M -MF -MP 等相关选项说明 - Jerry - CSDN博客