Make、编译选项、连接问题

上传人:博****1 文档编号:508347454 上传时间:2023-01-05 格式:DOCX 页数:95 大小:92KB
返回 下载 相关 举报
Make、编译选项、连接问题_第1页
第1页 / 共95页
Make、编译选项、连接问题_第2页
第2页 / 共95页
Make、编译选项、连接问题_第3页
第3页 / 共95页
Make、编译选项、连接问题_第4页
第4页 / 共95页
Make、编译选项、连接问题_第5页
第5页 / 共95页
点击查看更多>>
资源描述

《Make、编译选项、连接问题》由会员分享,可在线阅读,更多相关《Make、编译选项、连接问题(95页珍藏版)》请在金锄头文库上搜索。

1、cxMake使用问题、Gcc编译选项问题、GNU连接问题一、GNU Make使用make 工作自动确定工程的哪部分需要重新编译,执行命令去编译它们。虽然make多用于C程序,然而只要提供命令行的编译器,你可以将其用于任何语 言。如果要使用make,你必须写一个叫做一makefile的文件,这个文件描述工 程中文件之间的关系,提供更新每个文件的命令。典型的工程是这样的:可执行文件靠目标文件来更新,目标文件靠编译源文件来更新。Makefile写好之后,每次更改了源文件后,只要执行 make就足够了,所有 必要的重新编译将执行。Make程序利用makefile中的数据库和文件的最后修改 时间来确定那

2、个文件需要更新;对于需要更新的文件,make执行数据库中记录的命令。可以提供命令行参数给make来控制那个文件需要重新编译。1.1 Makefile 介绍Makefile文件告诉make做什么,多数情况是怎样编译和链接一个程序。这里有一个简单的makefile,描述如何编译链接由8个C文件和3个头文件 组成的一个编辑器:edit :insert.o serach.o files.o utils.oinsert.o search.o files.o utils.omain.o :main.c defs.hcc -c main.ckdb.o :cc -c kbd.cdisplay.o :displ

3、ay.c defs.h buffer.hcc -c display.cinsert.o :insert.c defs.h buffer.hcc -c insert.csearch.o :search.c defs.h buffer.hcc -c search.cfiles.o :cc -c files.cutils.o :utils.c defs.hcc -c utils.cclean :insert.o search.o files.o utils.o将长行用 分开便于阅读,这和使用一个长行的作用是一样的。使用这个makefile创建可执行文件“ediE寸运彳f make就可以了;如果要将可

4、执行文件和 目标文件删除,执行makecleanmake重新编译这个编辑器时,每个更改的C文件必须重新编译;如果头文件更改了,每个包含头文件的 C文件必须重新编译;每次编译产生一个对应于 原文件的目标文件。最终,目标文件链接在一起产生新的可执行文件。1.2 规则简介makefile 中的规则是这样的:TARGET:DEPENDENCESCOMMAND目标(TARGET程序产生的文件,如可执行文件和目标文件;目标也可以是要执行的动作,如“ clean。 ”依赖(DEPENDENCE隈用来产生目标的输入文件,一个目标通常依赖于 多个文件。命令(COMMAND)是make执行的动作,一个可以有多个命

5、令,每个占一 /一 行。注意:每个命令行的起始字符必须为 TAB字符!有依赖关系规则中的命令通常在依赖文件变化时负责产生target 文件,make执行这些命令更新或产生target。规则可以没有依赖关系,如包含 target “cle aW则。规则解释如何和何时重做该规则中的文件,make根据依赖关系执行产生或更新目标;规则也说明如何和何时执行动作。有的规则看起来很复杂,但都符 合上述模式。1.3 make 工作原理缺省make从第一个target开始(第一个非开始的target),这称作缺省 目标。在上述的makefile中,缺省目标是更新执行程序edit将这个目标置于最前面。当执行mak

6、e的时候,make程序从当前目录读入 makefile开始处理第 一个规则;在例子中,这个规则是重新链接edit在make处理这个规则之前,必须处理ed所依赖的那些文件的规则,例子中是目标文件。这些文件按 照他们自己的规则处理:通过编译源文件来更新每个.文件;当依赖关系中的源文件或头文件比目标文件新,或目标文件不存在时,必须重新编译。其它的规则被处理是因为他们的 target 是目标的依赖,和目标没有依赖关系的规则不会被处理,除非指定 make处理(如make clean)。在重新编译目标文件之前,make会试图更新它的依赖:源文件和头文件。例子中的 makefile 对源文件和头文件未指定任

7、何操作:.和.良件不是任何规则的目标。确认所有的目标文件都是最新的之后, make 决定是否重新链接 ed:it 如果ed群存在,或者任何一个目标文件都比它新,则链接工作将进行。1.4 使用变量在例子中,在规则edi由目标文件被列出来两次:edit :insert.o search.o files.o utils.oinsert.o search.o files.o utils.o这样的重复容易出错:假设工程中加入了一个新的目标文件,可能只将其加入了一个列表中;通过使用变量可以消除这种风险:变量允许一个预定义的字符串在多个地方被替换。insert.o :defs.h buffer.hsearc

8、h.o :defs.h buffer.hfiles.o :utils.o :defs.h.PHONY :cleanclean :-rm edit $(objects)1.6 另一种风格如果 makefile 中的目标都是以隐含规则生成,可以将规则按照依赖关系分组:insert.o search.o files.o utils.oedit :$(objects)cc -o edit $(objects)$(objects) :defs.h display.o insert.o search.o files.o : buffer.h这里defs.除为所有目标文件的依赖。这种风格是好是坏取决于个人喜

9、 好,它非常紧凑,但是将每个目标的依赖信息放在一起看起来更清楚一些。1.7 清理编写规则不至于编译程序。 Makefile 通常描述如何做其它事情:比如删除目录中的目标文件和可执行文件来清理目录。例子中是这样写的:clean:rm edit $(objects)实际情况是,我们需要处理一些意外事件:存在一个叫做clea的文件;如果rm出错,并不希望make过程停止下 来,修改过的版本如下:.PHONY :cleanclean :-rm edit $(objects)这样的规则当然不能放在makefile 的开始,因为这并不是我们缺省要做的工作。由于clea旃不是edit勺依赖,在运行make时

10、没有参数时,这条规则不 会执行;要执行这个规则,必须运行make clean MakefileMakefilexx 包含五种内容:显式规则,隐式规则,变量定义,指令(directive )和注释。显式规则描述如何生成规则的目标,它列出了目标依赖的文件,指定了 产生或更新目标的命令隐式规则描述如何生成基于文件名的一类文件,说明目标可能依赖于和 其文件名类似的文件,指定了相应的命令。指令类似与编译器的伪指令,包含:指示make读入另一个makefile决定是否忽略makefile中的一部分定义一个变量一行中?#开始是注释,直到行末,除非遇到续行符号。在defin和命令中不能有注释,其它情况下注释可

11、出现在任何地方。1.8 makefile 名字缺省情况下,make以下列名字查找 makefile:GNUmakefile “makefile Makefile(注意大小写)。通常你的 makefile 应叫做makefile Makefile “GNUmakefi库推荐,除非你的 makefile 是为 GNU的make定制的,其它的 make不认为该名字是一个 makefile的名字。如果你使用非标准命名的 makefile,必须用命令开关-f或一file参数 fNAME或 file NAME诉miake读入NAME作为makefile。如果使用多个该开 关,所有的文件将按顺序连接起来。如

12、果使用该选项,标准的 makefile名字不 会自动检测。1.9 包含?include指令告诉make暂停处理余下的内容,读入其它 makefile。语法如 下:include FILENAMES 这一行起始可以有空格,但 TAB字符不允许。如果文件名包含变量或函 数,这些将被扩展。1.10 MAKEFILEI如果环境变量MAKEFILE定义,make认为它的值是一系列空格隔开的文 件名,这些文件在处理其它 makefile前被make程序读入。这类似于include指 令;这些文件中的目标不会影响缺省目标,而且如果文件未找到的话,make并不认为是错误。这个变量的主要用途是递归引用 make

13、程序时通讯1.11 如何重新生成makefile有时候makefile是从其它文件生成的,比如RCS SCC故件。如果makefile是由其它文件生成的,需要 make读入最新版本的makefile。在读入所有makefile之后,make认为每个makefile是一个目标,试图去更 新它;如果makefile 中有一条如何更新它的规则,或者有适用的隐式规则,需要的更新会进行。所有的 makefile检查完之后,如果有的改变了,make重新开始再读入(make会试图再做更新,但通常不会再改变了,因为已经是最新的 了)。如果一个文件使用双冒号规则,提供了命令但没有依赖关系,文件始终会被更新。在m

14、akefile 的情况下,如果makefile 双冒号规则,提供了命令但没有依赖关系,这样makefile 始终会重新生成,这会导致循环:make只是在不断更新 makefile,却不干活。为避免这种情况,make不会重新生成那些只有命令没有依赖关系的双冒号规则的 makefile 。如果没有使用-f或-file选项,make会尝试缺省的makefile文件名。和指 明-f或-file选项不同,make不能确定这些文件是否应当存在。然而,如果缺 省makefile不存在但可以通过运行 make规则生成,你可能希望这些规则被运行 使得 makefile 可以使用。因此,如果没有缺省 makefi

15、le, make试图按照makefile名查找的顺序生成 它,直到成功或名字用完。注意如果 make不能找到或生成makefile,这并不是 错误; makefile 不总是必需的。当使用-t 或 -touch 选项时,不希望使用过时的 makefile 来决定那个目标来touch。所以-t选项对makefile更新不起作用;类似q (or?question)和- n (or just-print )不阻止makefile的更新,因为过时的 makefile会产生错误的 输出。这样make-mfile - n fo(会更新mfile读入它,打印出更新foo需要执行的命令但不运行这些命令。与fo有关的命令是更新过的mfil冲的内容。但是有时不希望更新 makefile,可以将makefile作为命令行的目标,当 makefile 被显式指定为目标时,-t 选项也适用于它们。这样make-mfile - n mfile fo诠

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

当前位置:首页 > 商业/管理/HR > 营销创新

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