makefile的编写步骤

makefile的好处:一次编写,终身受益
makefile的命名规则:

makefile
Makefile

makefile的三要素

  • 目标
  • 依赖
  • 规则命令

这三个要素当中,目标不可以不写,其余的两个要素可以不写。

写法

目标:依赖
tab键 规则命令

makefile的编写步骤

第一版makefile

makefile的编写步骤
makefile的编写步骤
缺点:如果只更改其中一个文件,所有的源码都重新编译
可以考虑编译过程分解,把.c的文件变为.o的文件。先生成.o文件,然后使用.o文件得到结果。
各个文件的以来关系图如下
makefile的编写步骤
据此,对makefile文件进行更新

第二版的makefile

makefile的编写步骤
makefile的编写步骤
可以看出,生成了.o文件。
还可以在makefile文件中定义变量。

第三版的makefile

makefile的编写步骤
makefile的隐含规则:处理第一个目标
函数:
wildcard 可以进行文件匹配
patsbst 文件的替换

所以,第四版makefile

makefile的编写步骤
makefile的编写步骤
其中make test指明是第二个目标。其中第一行输出代表的是echo 本身。第二行输出才是echo输出的内容。

第五版的makefile

makefile的编写步骤
相当于把.c文件名变为了.o文件名,然后在最后进行了echo打印输出,输出的内容如下:
makefile的编写步骤

第六版的makefile

makefile的编写步骤
makefile的编写步骤
第六版的makefile尽管已经很好了,但是仍然存在改进的余地。

第七版的makefile

makefile的变量:

  • [email protected] 代表目标
  • $^ 代表全部依赖
  • $< 代表第一个依赖
  • $? 第一个变化的依赖

makefile的编写步骤
makefile的编写步骤