makefile规则介绍工作原理如何编写

上传人:suns****4568 文档编号:91123249 上传时间:2019-06-23 格式:DOC 页数:27 大小:480.50KB
返回 下载 相关 举报
makefile规则介绍工作原理如何编写_第1页
第1页 / 共27页
makefile规则介绍工作原理如何编写_第2页
第2页 / 共27页
makefile规则介绍工作原理如何编写_第3页
第3页 / 共27页
makefile规则介绍工作原理如何编写_第4页
第4页 / 共27页
makefile规则介绍工作原理如何编写_第5页
第5页 / 共27页
点击查看更多>>
资源描述

《makefile规则介绍工作原理如何编写》由会员分享,可在线阅读,更多相关《makefile规则介绍工作原理如何编写(27页珍藏版)》请在金锄头文库上搜索。

1、目录目录 1简介简介.3 1.1准备工作.3 1.2MAKEFILE介绍.3 1.3规则简介.4 1.4MAKE工作原理.4 1.5使用变量.5 1.6简化命令.5 1.7另一种风格.6 1.8清理.6 2MAKEFILE.7 2.1MAKEFILE名字7 2.2包含.7 2.3MAKEFILE变量7 2.4如何重新生成MAKEFILE7 2.5重载MAKEFILE8 3规则规则.8 3.1例子.8 3.2规则的语法.9 3.3通配符.9 3.3.1通配符的缺陷9 3.3.2wildcard函数.10 3.4目录搜索.10 3.4.1VPATH.10 3.4.2选择性搜索11 3.4.3使用自

2、动变量11 3.4.4目录搜索和隐含规则12 3.5PHONY 目标12 3.6FORCE 目标.13 3.7空目标.13 3.8内建的特殊目标.13 3.9一个规则多个目标.14 3.10一个目标多条规则14 3.11静态模式规则.14 3.11.1语法15 3.11.2静态模式规则和隐式规则15 3.12双冒号规则16 3.13自动生成依赖关系16 4编写命令编写命令.17 4.1回显.17 4.2执行.17 4.3并行执行.17 4.4错误.18 4.5中断MAKE18 4.6递归使用.18 4.6.1MAKE变量19 4.6.2传递变量到子make 19 5命令行参数命令行参数.20

3、6参考参考.23 6.1指令.23 6.2函数.24 6.3自动变量.26 6.4特殊变量.27 GNU Make 使用使用 Make 程序最初设计是为了维护 C 程序文件防止不必要的重新编译。在使用命令行编 译器的时候,修改了一个工程中的头文件,如何确保包含这个头文件的所有文件都得到编 译?现在的版本生成是使用批处理程序,编译那些文件依赖于程序的维护者,在模块之间 相互引用头文件的情况下,要将所有需要重新编译的文件找出来是一件痛苦的事情;在找 到这些文件之后,修改批处理进行编译。实际上这些工作可以让 make 程序来自动完成, make 工具对于维护一些具有相互依赖关系的文件特别有用,它对文

4、件和命令的联系(在文 件改变时调用来更新其它文件的程序)提供一套编码方法。Make 工具的基本概念类似于 Proglog 语言,你告诉 make 需要做什么,提供一些规则,make 来完成剩下的工作。 1简介简介 make 工作自动确定工程的哪部分需要重新编译,执行命令去编译它们。虽然 make 多 用于 C 程序,然而只要提供命令行的编译器,你可以将其用于任何语言。实际上,make 工具的应用范围不仅于编程,你可以描述任和一些文件改变需要自动更新另一些文件的任 务来使用它。 1.1准备工作准备工作 如果要使用 make,你必须写一个叫做“makefile”的文件,这个文件描述工程中文件之 间

5、的关系,提供更新每个文件的命令。典型的工程是这样的:可执行文件靠目标文件来更 新,目标文件靠编译源文件来更新。 Makefile 写好之后,每次更改了源文件后,只要执行 make 就足够了,所有必要的重新 编译将执行。Make 程序利用 makefile 中的数据库和文件的最后修改时间来确定那个文件需 要更新;对于需要更新的文件,make 执行数据库中记录的命令。 可以提供命令行参数给 make 来控制那个文件需要重新编译。 1.2Makefile 介绍介绍 Makefile 文件告诉 make 做什么,多数情况是怎样编译和链接一个程序。 这里有一个简单的 makefile,描述如何编译链接由

6、 8 个 C 文件和 3 个头文件组成的一 个编辑器: edit : main.o kbd.o command.o display.o insert.o serach.o files.o utils.o cc o edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o main.o : main.c defs.h cc c main.c kdb.o : kbd.c defs.h command.h cc c kbd.c command.o : command.c defs.h command.h cc -c

7、 command.c display.o : display.c defs.h buffer.h cc -c display.c insert.o : insert.c defs.h buffer.h cc -c insert.c search.o : search.c defs.h buffer.h cc -c search.c files.o : files.c defs.h buffer.h command.h cc -c files.c utils.o : utils.c defs.h cc -c utils.c clean : rm edit main.o kbd.o command

8、.o display.o insert.o search.o files.o utils.o 将长行用分开便于阅读,这和使用一个长行的作用是一样的。使用这个 makefile 创建 可执行文件“edit”时运行 make 就可以了;如果要将可执行文件和目标文件删除,执行 make clean make 重新编译这个编辑器时,每个更改的 C 文件必须重新编译;如果头文件更改了, 每个包含头文件的 C 文件必须重新编译;每次编译产生一个对应于原文件的目标文件。最 终,目标文件链接在一起产生新的可执行文件。 1.3规则简介规则简介 makefile 中的规则是这样的: TARGET : DEPEND

9、ENCIES COMMAND 目标(TARGET)程序产生的文件,如可执行文件和目标文件;目标也可以是要执行 的动作,如“clean” 。 依赖(DEPENDENCIES)是用来产生目标的输入文件,一个目标通常依赖于多个文件。 命令(COMMAND)是 make 执行的动作,一个可以有多个命令,每个占一行。注意: 每个命令行的起始字符必须为 TAB 字符! 有依赖关系规则中的命令通常在依赖文件变化时负责产生 target 文件,make 执行这些 命令更新或产生 target。规则可以没有依赖关系,如包含 target “clean”的规则。 规则解释如何和何时重做该规则中的文件,make 根

10、据依赖关系执行产生或更新目标; 规则也说明如何和何时执行动作。有的规则看起来很复杂,但都符合上述模式。 1.4make 工作原理工作原理 缺省 make 从第一个 target 开始(第一个非 . 开始的 target) ,这称作缺省目标。在上 述的 makefile 中,缺省目标是更新执行程序edit,将这个目标置于最前面。当执行 make 的时候,make 程序从当前目录读入 makefile 开始处理第一个规则;在例子中,这个规则是 重新链接edit;在 make 处理这个规则之前,必须处理edit所依赖的那些文件的规则,例 子中是目标文件。这些文件按照他们自己的规则处理:通过编译源文件

11、来更新每个.o文件; 当依赖关系中的源文件或头文件比目标文件新,或目标文件不存在时,必须重新编译。 其它的规则被处理是因为他们的 target 是目标的依赖,和目标没有依赖关系的规则不 会被处理,除非指定 make 处理(如 make clean) 。 在重新编译目标文件之前,make 会试图更新它的依赖:源文件和头文件。例子中的 makefile 对源文件和头文件未指定任何操作:.c和.h文件不是任何规则的目标。确认所有 的目标文件都是最新的之后,make 决定是否重新链接edit:如果edit不存在,或者任何 一个目标文件都比它新,则链接工作将进行。 这样,如果我们改变 insert.c

12、运行 make,make 会编译这个文件来更新insert.o,然后 链接edit;如果修改了command.h运行 make, kbd.o, command.o, files.o会重新生成, 链接edit。 1.5使用变量使用变量 在例子中,在规则edit中,目标文件被列出来两次: edit : main.o kbd.o command.o display.o insert.o search.o files.o utils.o cc -o edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o 这样的重复

13、容易出错:假设工程中加入了一个新的目标文件,可能只将其加入了一个 列表中;通过使用变量可以消除这种风险:变量允许一个预定义的字符串在多个地方被替 换。 在 makefile 中,可以写这样一行来定义object变量: objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o 于是在需要目标文件名列表的地方,使用$(object) 来代替变量的值。以下是使用了变 量以后的 makefile: objects = main.o kbd.o command.o display.o insert.o sea

14、rch.o files.o utils.o edit : $(objects) cc -o edit $(objects) main.o : main.c defs.h cc -c main.c kbd.o : kbd.c defs.h command.h cc -c kbd.c command.o : command.c defs.h command.h cc -c command.c display.o : display.c defs.h buffer.h cc -c display.c insert.o : insert.c defs.h buffer.h cc -c insert.c

15、 search.o : search.c defs.h buffer.h cc -c search.c files.o : files.c defs.h buffer.h command.h cc -c files.c utils.o : utils.c defs.h cc -c utils.c clean : rm edit $(objects) 1.6简化命令简化命令 为每个文件写出编译命令不是必要的,因为 make 可以自己来做;以.c文件更新.o文 件有一个隐含的规则,使用cc -c命令。Make 将利用cc c main.c o main.o来将 main.c 编 译为 main.o

16、,因此在生成目标文件的规则中,可以省略命令。 当.c文件以这样的方式使用时,将自动加入到依赖关系中;由是在省略命令的前提下, 可以将.c文件从依赖关系中省略。以下是简化过的 makefile: objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o edit : $(objects) cc -o edit $(objects) main.o : defs.h kbd.o : defs.h command.h command.o : defs.h command.h display.o : defs.h buffer.h insert.o : defs.h buffer.h search.o : defs.h buffer.h files.o : defs.h buffer.h command.h utils.o : defs.h

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号