makefile的编写步骤
makefile的好处:一次编写,终身受益
makefile的命名规则:
makefile
Makefile
makefile的三要素
- 目标
- 依赖
- 规则命令
这三个要素当中,目标不可以不写,其余的两个要素可以不写。
写法
目标:依赖
tab键 规则命令
第一版makefile
缺点:如果只更改其中一个文件,所有的源码都重新编译
可以考虑编译过程分解,把.c的文件变为.o的文件。先生成.o文件,然后使用.o文件得到结果。
各个文件的以来关系图如下
据此,对makefile文件进行更新
第二版的makefile
可以看出,生成了.o文件。
还可以在makefile文件中定义变量。
第三版的makefile
makefile的隐含规则:处理第一个目标
函数:
wildcard 可以进行文件匹配
patsbst 文件的替换
所以,第四版makefile
其中make test指明是第二个目标。其中第一行输出代表的是echo 本身。第二行输出才是echo输出的内容。
第五版的makefile
相当于把.c文件名变为了.o文件名,然后在最后进行了echo打印输出,输出的内容如下:
第六版的makefile
第六版的makefile尽管已经很好了,但是仍然存在改进的余地。
第七版的makefile
makefile的变量:
- [email protected] 代表目标
- $^ 代表全部依赖
- $< 代表第一个依赖
- $? 第一个变化的依赖