Makefile 学习教程: 跟我一起写 Makefile 0 Makefile 概述 0.1 关于程序的编译和链接 1 Makefile 介绍 1.1 Makefile 的规则 1.2 一个示例 1.3 make 是如何工作的 1.4 makefile 中使用变量 1.5 让 make 自动推导 1.6 另类风格的 makefile 1.7 清空目标文件的规则 2 Makefile 总述 2.1 Makefile 里有什么? 2.2Makefile 的文件名 2.3 引用其它的 Makefile 2.4 环境变量 MAKEFILES 2.5 make 的工作方式 3 Makefile 书写规则 3.1 规则举例 3.2 规则的语法 3.3 在规则中使用通配符 3.4 文件搜寻 3.5 伪目标 3.6 多目标 3.7 静态模式 3.8 自动生成依赖性 4 Makefile 书写命令 4.1 显示命令 4.2 命令执行 4.3 命令出错 4.4 嵌套执行 make 4.5 定义命令包 0 Makefile 概述 -------------------------------------------------------------------------------- 什么是 makefile?或许很多 Winodws 的程序员都不知道这个东西,因为那些 Windows 的 IDE都为你做了这个工作,但我觉得要作一个好的和 professional 的程序员,makefile 还是要懂。这就好像现在有这么多的 HTML 的编辑器,但如果你想成为一个专业人士,你还是要了解HTML 的标识的含义。特别在 Unix下的软件编译,你就不能不自己写 makefile 了,会不会写 makefile,从一个侧面说明了一个人是否具备完成大型工程的能力。 因为,makefile 关系到了整个工程的编译规则。一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile 定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile 就像一个 Shell 脚本一样,其中也可以执行操作系统的命令。 makefile 带来的好处就是——“自动化编译”,一旦写好,只需要一个 make 命令,整个工程完全自动编译,极大的提高了软件开发的效率。make 是一个命令工具,是一个解释 makefile中指令的命令工具,一般来说,大多数的IDE 都有这个命令,比如:Delphi 的make,Visual C++的nmake,Linux下 GNU 的make。可见,makefile 都成为了一种在工程方面的编译方法。 现在讲述如何写 makefile 的文章比较少,这是我想写这篇文章的原因。当然,不同产商的make 各不相同,也有不同的语法,但其本质都是在“文件依赖性”上做文章,这...