Makefile文档
组织管理程序
不使用Makefile的缺点
-o test a.c b.c
执行过程:
a.c文件通过预处理、编译、汇编得到a.o文件
b.c文件通过预处理、编译、汇编得到b.o文件
a.o文件与b.o文件通过链接,得到test可执行文件
这种方式的缺点:如果仅仅对a.c文件内容进行修改,执行命令后,b.c文件也会重新编译、链接,效率降低。
Makefile的规则
makefie最基本的语法是规则,规则:
目标 : 依赖1 依赖2 ...
[TAB]命令
当“依赖”比“目标”新,执行它们下面的命令。我们要把上面三个命令写成makefile规则,如下:
test :a.o b.o //test是目标,它依赖于a.o b.o文件,一旦a.o或者b.o比test新,就执行下面的命令,重新生成test可执行程序。
gcc -o test a.o b.o
a.o : a.c //a.o依赖于a.c,当a.c更加新的话,执行下面的命令来生成a.o
gcc -c -o a.o a.c
b.o : b.c //b.o依赖于b.c,当b.c更加新的话,执行下面的命令,来生成b.o
gcc -c -o b.o b.c
通配符
假如一个目标文件所依赖的依赖文件很多,那样岂不是我们要写很多规则,这显然是不合乎常理的.我们可以使用通配符,来解决这些问题。
对上节程序进行修改代码如下:
test: a.o b.o
gcc -o test $^
%.o : %.c
gcc -c -o $@ $<
%.o:表示所用的.o文件
%.c:表示所有的.c文件
$@:表示目标
$<:表示第1个依赖文件
$^:表示所有依赖文件
假想目标:.PHONY
我们想清除文件,我们在Makefile的结尾添加如下代码就可以了:
clean:
rm *.o test
*1)执行 make :生成第一个可执行文件。
*2)执行 make clean : 清除所有文件,即执行: rm *.o test。
如果:该目录下面有名为clean文件怎么办呢?
我们在该目录下创建一个名为 “clean” 的文件,然后重新执行:make然后make
clean,结果(会有下面的提示:):
make: \`clean' is up to date.
它根本没有执行我们的删除操作,这是为什么呢?
我们之前说,一个规则能过执行的条件:
*1)目标文件不存在
*2)依赖文件比目标新
解决办法:我们需要把目标定义为假象目标,用关键字PHONY
.PHONY: clean //把clean定义为假象目标。他就不会判断名为“clean”的文件是否存在,
然后在Makfile结尾添加.PHONY: clean语句,重新执行:make clean,就会执行删除操作。
变量
在makefile中有两种变量:
1), 简单变量(即使变量):
A := xxx # A的值即刻确定,在定义时即确定
2)延时变量
B = xxx # B的值使用到时才确定
:= # 即时变量
= # 延时变量
?= # 延时变量, 如果是第1次定义才起效, 如果在前面该变量已定义则忽略这句
+= # 附加, 它是即时变量还是延时变量取决于前面的定义
?= # 如果这个变量在前面已经被定义了,这句话就会不会起效果,
实例:
A := $(C)
B = $(C)
C = abc
D = hello
D ?= world
all:
@echo A = $(A) # $(变量名)表示变量值
@echo B = $(B)
@echo D = $(D)
C += 123
执行:
make
结果:
A =
B = abc 123
D = hello
标签:文件,变量,make,Makefile,clean,Linux,test,执行,浅析
From: https://www.cnblogs.com/Tayoou/p/17114424.html