1、背景原理
- 一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile 定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。
- makefile 带来的好处就是——“自动化编译”,一旦写好,只需要一个 make 命令,整个工程完全自动编译,极大的提高了软件开发的效率。
- make是一个命令工具,是一个解释 makefile 中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile 都成为了一种在工程方面的编译方法。
- make 是一条命令,makefile 是一个文件,两个搭配使用,完成项目自动化构建。
2、项目清理
- 工程是需要被清理的。
- 像 clean 这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行。 不过,我们可以显示用 make 执行。即命令
make clean
,以此来清除所有的目标文件,以便重编译。- 但是一般我们这种 clean 的目标文件,我们将它设置为伪目标,用
.PHONY
修饰,伪目标的特性是:总是被执行的。
3、常见用法
- 指令前带 @ 符号,执行命令时,指令不会显示出来
- Makefile 中用 # 来注释内容
- Makefile 中允许编写变量(最好不带空格),允许变量替换的
- Makefile 中支持依赖关系简写【$ ^ 代表源文件 ,$@ 代表目标文件】
- 例: