MakeFile规则介绍、工作原理、如何编写.doc
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《MakeFile规则介绍、工作原理、如何编写.doc》由会员分享,可在线阅读,更多相关《MakeFile规则介绍、工作原理、如何编写.doc(27页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、如有侵权,请联系网站删除,仅供学习与交流MakeFile规则介绍、工作原理、如何编写【精品文档】第 27 页目录1简介31.1准备工作31.2Makefile介绍31.3规则简介41.4make工作原理41.5使用变量51.6简化命令51.7另一种风格61.8清理62MAKEFILE72.1makefile名字72.2包含72.3MAKEFILE变量72.4如何重新生成makefile72.5重载makefile83规则83.1例子83.2规则的语法93.3通配符93.3.1通配符的缺陷93.3.2wildcard函数103.4目录搜索103.4.1VPATH103.4.2选择性搜索113.4
2、.3使用自动变量113.4.4目录搜索和隐含规则123.5PHONY目标123.6FORCE目标133.7空目标133.8内建的特殊目标133.9一个规则多个目标143.10一个目标多条规则143.11静态模式规则143.11.1语法153.11.2静态模式规则和隐式规则153.12双冒号规则163.13自动生成依赖关系164编写命令174.1回显174.2执行174.3并行执行174.4错误184.5中断make184.6递归使用184.6.1MAKE变量194.6.2传递变量到子make195命令行参数206参考236.1指令236.2函数246.3自动变量266.4特殊变量27GNU M
3、ake使用Make 程序最初设计是为了维护C程序文件防止不必要的重新编译。在使用命令行编译器的时候,修改了一个工程中的头文件,如何确保包含这个头文件的所有文件都得到编译?现在的版本生成是使用批处理程序,编译那些文件依赖于程序的维护者,在模块之间相互引用头文件的情况下,要将所有需要重新编译的文件找出来是一件痛苦的事情;在找到这些文件之后,修改批处理进行编译。实际上这些工作可以让make程序来自动完成,make工具对于维护一些具有相互依赖关系的文件特别有用,它对文件和命令的联系(在文件改变时调用来更新其它文件的程序)提供一套编码方法。Make工具的基本概念类似于Proglog语言,你告诉make需
4、要做什么,提供一些规则,make来完成剩下的工作。1 简介make工作自动确定工程的哪部分需要重新编译,执行命令去编译它们。虽然make多用于C程序,然而只要提供命令行的编译器,你可以将其用于任何语言。实际上,make工具的应用范围不仅于编程,你可以描述任和一些文件改变需要自动更新另一些文件的任务来使用它。1.1 准备工作如果要使用make,你必须写一个叫做“makefile”的文件,这个文件描述工程中文件之间的关系,提供更新每个文件的命令。典型的工程是这样的:可执行文件靠目标文件来更新,目标文件靠编译源文件来更新。Makefile写好之后,每次更改了源文件后,只要执行make就足够了,所有必
5、要的重新编译将执行。Make程序利用makefile中的数据库和文件的最后修改时间来确定那个文件需要更新;对于需要更新的文件,make执行数据库中记录的命令。可以提供命令行参数给make来控制那个文件需要重新编译。1.2 Makefile介绍Makefile文件告诉make做什么,多数情况是怎样编译和链接一个程序。这里有一个简单的makefile,描述如何编译链接由8个C文件和3个头文件组成的一个编辑器:edit : main.o kbd.o command.o display.o insert.o serach.o files.o utils.occ o edit main.o kbd.o
6、command.o display.o insert.o search.o files.o utils.omain.o : main.c defs.hcc c main.ckdb.o : kbd.c defs.h command.hcc c kbd.ccommand.o : command.c defs.h command.hcc -c command.cdisplay.o : display.c defs.h buffer.hcc -c display.cinsert.o : insert.c defs.h buffer.hcc -c insert.csearch.o : search.c
7、defs.h buffer.hcc -c search.cfiles.o : files.c defs.h buffer.h command.hcc -c files.cutils.o : utils.c defs.hcc -c utils.cclean :rm edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o将长行用分开便于阅读,这和使用一个长行的作用是一样的。使用这个makefile创建可执行文件“edit”时运行make就可以了;如果要将可执行文件和目标文件删除,执行make cleanmake
8、重新编译这个编辑器时,每个更改的C文件必须重新编译;如果头文件更改了,每个包含头文件的C文件必须重新编译;每次编译产生一个对应于原文件的目标文件。最终,目标文件链接在一起产生新的可执行文件。1.3 规则简介makefile中的规则是这样的:TARGET : DEPENDENCIES COMMAND目标(TARGET)程序产生的文件,如可执行文件和目标文件;目标也可以是要执行的动作,如“clean”。依赖(DEPENDENCIES)是用来产生目标的输入文件,一个目标通常依赖于多个文件。命令(COMMAND)是make执行的动作,一个可以有多个命令,每个占一行。注意:每个命令行的起始字符必须为TA
9、B字符!有依赖关系规则中的命令通常在依赖文件变化时负责产生target文件,make执行这些命令更新或产生target。规则可以没有依赖关系,如包含target “clean”的规则。规则解释如何和何时重做该规则中的文件,make根据依赖关系执行产生或更新目标;规则也说明如何和何时执行动作。有的规则看起来很复杂,但都符合上述模式。1.4 make工作原理缺省make从第一个target开始(第一个非 . 开始的target),这称作缺省目标。在上述的makefile中,缺省目标是更新执行程序edit,将这个目标置于最前面。当执行make的时候,make程序从当前目录读入makefile开始处理
10、第一个规则;在例子中,这个规则是重新链接edit;在make处理这个规则之前,必须处理edit所依赖的那些文件的规则,例子中是目标文件。这些文件按照他们自己的规则处理:通过编译源文件来更新每个.o文件;当依赖关系中的源文件或头文件比目标文件新,或目标文件不存在时,必须重新编译。其它的规则被处理是因为他们的target是目标的依赖,和目标没有依赖关系的规则不会被处理,除非指定make处理(如make clean)。在重新编译目标文件之前,make会试图更新它的依赖:源文件和头文件。例子中的makefile对源文件和头文件未指定任何操作:.c和.h文件不是任何规则的目标。确认所有的目标文件都是最新
11、的之后,make决定是否重新链接edit:如果edit不存在,或者任何一个目标文件都比它新,则链接工作将进行。这样,如果我们改变insert.c运行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.occ -o edit main.o kbd.o co
12、mmand.o display.o insert.o search.o files.o utils.o这样的重复容易出错:假设工程中加入了一个新的目标文件,可能只将其加入了一个列表中;通过使用变量可以消除这种风险:变量允许一个预定义的字符串在多个地方被替换。在makefile中,可以写这样一行来定义object变量:objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o于是在需要目标文件名列表的地方,使用$(object) 来代替变量的值。以下是使用了变量以后的makefile:objects =
13、 main.o kbd.o command.o display.o insert.o search.o files.o utils.oedit : $(objects)cc -o edit $(objects)main.o : main.c defs.hcc -c main.ckbd.o : kbd.c defs.h command.hcc -c kbd.ccommand.o : command.c defs.h command.hcc -c command.cdisplay.o : display.c defs.h buffer.hcc -c display.cinsert.o : inse
14、rt.c defs.h buffer.hcc -c insert.csearch.o : search.c defs.h buffer.hcc -c search.cfiles.o : files.c defs.h buffer.h command.hcc -c files.cutils.o : utils.c defs.hcc -c utils.cclean :rm edit $(objects)1.6 简化命令为每个文件写出编译命令不是必要的,因为make可以自己来做;以.c文件更新.o文件有一个隐含的规则,使用cc -c命令。Make将利用cc c main.c o main.o来将ma
15、in.c编译为main.o,因此在生成目标文件的规则中,可以省略命令。当.c文件以这样的方式使用时,将自动加入到依赖关系中;由是在省略命令的前提下,可以将.c文件从依赖关系中省略。以下是简化过的makefile:objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.oedit : $(objects) cc -o edit $(objects)main.o : defs.hkbd.o : defs.h command.hcommand.o : defs.h command.hdisplay.o :
16、defs.h buffer.hinsert.o : defs.h buffer.hsearch.o : defs.h buffer.hfiles.o : defs.h buffer.h command.hutils.o : defs.h.PHONY : cleanclean : -rm edit $(objects)1.7 另一种风格如果makefile中的目标都是以隐含规则生成,可以将规则按照依赖关系分组:objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.oedit : $(objects)
17、cc -o edit $(objects)$(objects) : defs.hkbd.o command.o files.o : command.hdisplay.o insert.o search.o files.o : buffer.h这里defs.h作为所有目标文件的依赖。这种风格是好是坏取决于个人喜好,它非常紧凑,但是将每个目标的依赖信息放在一起看起来更清楚一些。1.8 清理编写规则不至于编译程序。Makefile通常描述如何做其它事情:比如删除目录中的目标文件和可执行文件来清理目录。例子中是这样写的:clean: rm edit $(objects)实际情况是,我们需要处理一些意外
18、事件:存在一个叫做clean的文件;如果rm出错,并不希望make过程停止下来,修改过的版本如下:.PHONY : cleanclean : -rm edit $(objects)这样的规则当然不能放在makefile的开始,因为这并不是我们缺省要做的工作。由于clean并不是edit的依赖,在运行make时没有参数时,这条规则不会执行;要执行这个规则,必须运行make clean。2 MakefileMakefile中包含五种内容:显式规则,隐式规则,变量定义,指令(directive)和注释。l 显式规则描述如何生成规则的目标,它列出了目标依赖的文件,指定了产生或更新目标的命令l 隐式规则
19、描述如何生成基于文件名的一类文件,说明目标可能依赖于和其文件名类似的文件,指定了相应的命令。l 指令类似与编译器的伪指令,包含: 指示make读入另一个makefile 决定是否忽略makefile中的一部分 定义一个变量l 一行中#开始是注释,直到行末,除非遇到续行符号。在define和命令中不能有注释,其它情况下注释可出现在任何地方。2.1 makefile名字缺省情况下,make以下列名字查找makefile:GNUmakefile,makefile和Makefile(注意大小写)。通常你的makefile应叫做makefile或Makefile。GNUmakefile不推荐,除非你的m
20、akefile是为GNU的make定制的,其它的make不认为该名字是一个makefile的名字。如果你使用非标准命名的makefile,必须用命令开关-f 或 file。参数 f NAME或file NAME告诉make读入NAME作为makefile。如果使用多个该开关,所有的文件将按顺序连接起来。如果使用该选项,标准的makefile名字不会自动检测。2.2 包含include指令告诉make暂停处理余下的内容,读入其它makefile。语法如下:include FILENAMES 这一行起始可以有空格,但TAB字符不允许。如果文件名包含变量或函数,这些将被扩展。2.3 MAKEFILE
21、变量如果环境变量MAKEFILE已定义,make认为它的值是一系列空格隔开的文件名,这些文件在处理其它makefile前被make程序读入。这类似于include指令;这些文件中的目标不会影响缺省目标,而且如果文件未找到的话,make并不认为是错误。这个变量的主要用途是递归引用make程序时通讯2.4 如何重新生成makefile有时候makefile是从其它文件生成的,比如RCS或SCCS文件。如果makefile是由其它文件生成的,需要make读入最新版本的makefile。在读入所有makefile之后,make认为每个makefile是一个目标,试图去更新它;如果makefile中有一
22、条如何更新它的规则,或者有适用的隐式规则,需要的更新会进行。所有的makefile检查完之后,如果有的改变了,make重新开始再读入(make会试图再做更新,但通常不会再改变了,因为已经是最新的了)。如果一个文件使用双冒号规则,提供了命令但没有依赖关系,文件始终会被更新。在makefile的情况下,如果makefile双冒号规则,提供了命令但没有依赖关系,这样makefile始终会重新生成,这会导致循环:make只是在不断更新makefile,却不干活。为避免这种情况,make不会重新生成那些只有命令没有依赖关系的双冒号规则的makefile。如果没有使用-f或-file选项,make会尝试缺
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- MakeFile 规则 介绍 工作 原理 如何 编写
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内