What:
Makefile是脚本文件,内容为编译命令,著名所有需要编译的文件,当工程很大有很多需要编译的文件时就很方便了,用make命令调用Makefile即可。
How:
1. 明确Makefile规则
target: prerequisites
command
...
...
target 编译目标,可以是一个或多个目标文件、执行文件、标签
prerequisites 生成目标依赖的文件或目标
target:prerequisites 定义依赖关系
command 是用prerequisites生成target是的命令,前面用Tap缩进,执行规则:target 不存在或者 prerequisites 比 target 新就执行
make执行时先找到第一个target作为编译的最终目标,然后依次寻找依赖关系,执行command生成需要的文件
如果1个target没有与第1个target关联,则执行用make target
编译完成要清理中间生成的文件则可以在最后定义clean
.PHONY:clean(说明clean是伪目标)
clean: -rm .o kbd.o command.o display.o insert.o search.o files.o utils.o(加“-”表示即使有文件有问题,仍继续后面的工作)
2. 简化方法
1)使用变量简化文件:对于重复出现的文件可以用变量代替
2)使用自动推导进一步简化文件:省略显而易见的文件,比如生成main.o必然用到main.c则main.c就可以省略,同样用到的command也可以省略
3)对有相同依赖文件的target进行归类描述
4) 有用的符号定义
$@ 表示目标文件
$^ 表示所有的依赖文件
$< 表示第一个依赖文件
$? 表示比目标还要新的依赖文件列表
参考资料
[1]http://wiki.ubuntu.org.cn/跟我一起写Makefile:MakeFile介绍#makefile.E7.9A.84.E8.A7.84.E5.88.99
[2]https://www.youtube.com/watch?v=i3tYp88YHbI&t=317s
[3]https://blog.csdn.net/Mahfaeraak/java/article/details/87302048