命名:
- 都小写
- 第一个字母大写,其余小写
规则:
目标,依赖,命令
第一种方式:
app:main.c sub.c add.c
gcc main.c sub.c add.c
#使用make后生成可执行文件名为app
缺点:当文件数量庞大时,修改其中一个文件会涉及到所有文件的修改,效率十分低下
第二种方式:
Makefile原理:
需要生成的可执行文件一定要在第一排
通过时间的目标与依赖的时间关系检查是否需要更新
Makefile变量
在Vim里用%进行字符匹配,不是*
Makefile中的自动变量:
- $< 规则中的第一个依赖
- $@ 规则中的目标
- $^ 规则中的所有依赖
只能使用与规则命令中
app:main.c sub.c div.c add.c
gcc $^ -o $@ //前者替代所有.c 文件,后者替代app
Makefile系统变量(大写)(略)
makefile函数
所有函数都有返回值,通过函数得到obj的值:
src = wildcard ./.c 得到当前目录所有.c结尾文件
obj = patsubst ./.c, ./*.o, $(src) 将src内所有.c文件更名为.o文件
👆删除obj的内容(.o文件)和target内容(可执行文件)
通过命令行make clean命令执行
如果当前目录下存在文件名为 clean 的文件时,当我们在 shell 中执行命令 make clean,由于这个规则没有依赖文件,所以目标被认为是最新的而不去执行规则所定义的命令。因此命令 rm 将不会被执行。伪目标不会创建目标文件,只是想去执行这个目标下面的命令。
使用伪目标有两点原因:
- 避免我们的 Makefile 中定义的只执行的命令的目标和工作目录下的实际文件出现名字冲突。
- 提高执行 make 时的效率,特别是对于一个大型的工程来说,提高编译的效率也是我们所必需的。
在命令前面加-,如果命令执行失败则跳过,防止命令执行到一半因错误而导致程序崩溃