Makefile:项目管理工具
1.命名:makefile”和“Makefile”这两种默认文件名;自定义命名,如:如:“Make.Linux”特定的Makefile,你可以使用make的“-f”和“–file”参数,如:make -f Make.Linux或make --file Make.AIX。
2.规则:目标:依赖文件
Tab缩进+命令
3.makefile中写的第一个目标就是最终的目标;为了每次只编译修改的文件可以将所有的源文件(.c)写各自的编译;此时编译第一个时会根据需要在后面查找对应的依赖的规则,当所有的依赖都生成后才会执行第一个规则。
4.makefile中自动变量
$<:规则中第一个依赖;
$@:规则中的目标;
$^:规则中的所有依赖;
注意:以上自动变量只能在规则的命令中使用。根据模式规则将%替换。
分析:先执行第一个规则,遇到main.o就会向下查找,然后在公式中将%替换为main,然后执行gcc -c $< -o $
@
此
时
的
@ 此时的
@此时的<就是main.c,$@就是main.o;执行完成后继续执行第一个规则遇到add.o然后同理向下查找执行,直到所有的都生成就执行第一个生成终极目标。
Makefile中有自己维护的变量,大写一般是系统维护的变量,比如:CC=gcc
5.makefile中函数使用
注意:makefile中所有函数都是有返回值的。
获取指定目录下的所有.c文件;比如获取当前路径下所有.c:src=
(
w
i
l
d
c
a
r
d
.
/
∗
.
c
)
获
取
文
件
中
所
有
的
.
o
文
件
;
比
如
获
取
当
前
路
径
下
所
有
.
o
:
o
b
j
=
(wildcard ./*.c) 获取文件中所有的.o文件;比如获取当前路径下所有.o:obj=
(wildcard./∗.c)获取文件中所有的.o文件;比如获取当前路径下所有.o:obj=(patsubst ./%.c,./%.o,$(src))
make clean第一次就会删除,再次执行时会出现没有目录或文件;可以加参数-f就可以执行不提示了。加.PHONY就可声明伪目标,伪目标不会检查更新,所以只要执行就会执行。
当前命令前面加-如果执行失败就会忽略这条命令继续向下执行。
深## 标题入学习makefile请参考大神的makefile书籍(单击进入)