开发环境与工具makefile.pptxVIP

  1. 1、本文档共22页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

Linuxmakefile

MakefileMakefileGNUmake最初是Unix系统下的一个工具,设计之初是为了维护C程序文件不必要的重新编译,它是一个自动生成和维护目标程序的工具。make是一个解释Makefile文件中指令的命令工具,其最基本的功能就是通过Makefile文件来描述源程序之间的相互关系并自动维护编译工作,它会告知系统以何种方式编译和链接程序。

MakefileMakefileMakefile写好之后,每次改变了某些源文件,只要执行make命令:#make所有必要的重新编译将执行。Make程序利用makefile中的数据和每个文件的最后修改时间来确定那个文件需要更新,对于需要更新的文件,make程序执行makefile数据中定义的命令来更新。

MakefileMakefileGNUmake的主要功能是读进一个文本文件makefile并根据makefile的内容执行一系列的工作。makefile的默认文件名为GNUmakefile、makefile或Makefile,当然也可以在make的命令行中指定别的文件名。如果不特别指定,make命令在执行时将按顺序查找默认的makefile文件。多数Linux程序员使用第三种文件名Makefile。因为第一个字母是大写,通常被列在一个目录的文件列表的最前面。

MakefileMakefile是一个文本形式的数据库文件,其中包含一些规则来告诉make处理哪些文件以及如何处理这些文件。这些规则主要是描述哪些文件(称为target目标文件,不要和编译时产生的目标文件相混淆)是从哪些别的文件(称为dependency依赖文件)中产生的,以及用什么命令(command)来执行这个过程。依靠这些信息,make会对磁盘上的文件进行检查,如果目标文件的生成或被改动时的时间(称为该文件时间戳)至少比它的一个依赖文件还旧的话,make就执行相应的命令,以更新目标文件。目标文件不一定是最后的可执行文件,可以是任何一个中间文件并可以作为其他目标文件的依赖文件。

Makefile通常状况之下GNUmake的工作流程如下。 ①查找当前目录下的Makefile文件 ②初始化文件中的变量 ③分析Makefile中的所有规则 ④为所有的目标文件创建依赖关系 ⑤根据依赖关系,决定哪些目标文件要重新生成 ⑥执行生成命令

Makefile一个Makefile文件主要含有一系列的规则,每条规则包含以下内容。一个目标(target),即make最终需要创建的文件,如可执行文件和目标文件;目标也可以是要执行的动作,如“clean”。一个或多个依赖文件(dependency)列表,通常是编译目标文件所需要的其他文件。一系列命今(command),是make执行的动作,通常是把指定的相关文件编译成目标文件的编译命令,每个命令占一行,且每个命令行的起始字符必须为TAB字符。

Makefile假定一个项目中有以下一些文件。源程序:Main.c、test1.c、test.c。包含的头文件:head1.h、head2.h、head3.h。由源程序和头文件编译生成的目标文件:Main.o、test1.o、test2.o。由目标文件链接生成的可执行文件:test。main.chead1.hhead2.htest1.ctest2.chead3.hmain.otest1.otest2.otest

Makefilemakefile文件例子#MakefileExampletest:main.otest1.otest2.ogcc–otestmain.otest1.otest2.omain.o:main.chead1.hhead2.hgcc–cmain.ctest1.o:test1.chead2.hgcc–ctest1.ctest2.o:test2.chead3.hgcc–ctest2.cinstall:cptest/home/tmpclean:rm–f*.o

Makefile标准形式如下 make[选项][宏定义][目标文件] Make命令的一些常用选项及其含义如下。-ffile:指定Makefile的文件名。-n:打印出所有执行命令,但事实上并不执行这些命令。-s:在执行时不打印命令名。-w:如果在make执行时要改变目录,则打印当前的执行目录。-d:打印调试信息。-Idirname:指定所用Makefile所在的目录。-h:help文档,显示Makefile的help信息。

Makefile参数【目标文件】对于make命令来说也是一个可选项,如果在执行make命令时带有该参

文档评论(0)

zhishifuwu + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档