- Makefile学习教程: 跟我一起写 Makefile
- 0 Makefile概述
- 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各不相同,也有不同的语法,但其本质都是在“文件依赖性”上做文章,这里,我仅对GNU的make进行讲述,我的环境是RedHat Linux 8.0,make的版本是3.80.必竟,这个make是应用最为广泛的,也是用得最多的. 其还是最遵循于IEEE 1003.2-1992 标准的(POSIX.2).
在这篇文档中,将以C/C 的源码作为我们基础, 必然涉及一些关于C/C 的编译的知识,相关于这方面的内容,还请各位查看相关的编译器的文档.这里所默认的编译器是UNIX下的GCC和CC.
0.1 关于程序的编译和链接
在此,我想多说关于程序编译的一些规范和方法,一般来说,无论是C、C 、还是pas, 要把源文件编译成中间代码文件,在Windows下也就是 .obj 文件,UNIX下是 .o 文件,即 Object File,这个动作叫做编译(compile).然后再把大量的Object File合成执行文件,这个动作叫作链接(link).
编译时,编译器需要的是语法的正确,函数与变量的声明的正确.对于后者,通常是你需 |