- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
【精选】第二章 Linux C编程基础--make
第二章 Linux C编程基础--make makefile Makefile示例 Makefile里有什么? 1、 显式规则。 显式规则说明了,如何生成一个或多的的目标文件。 这是由Makefile的书写者明显指出,要生成的文件,文件的依赖文件,生成的命令。 2、隐式规则。由于我们的make有自动推导的功能,所以隐晦的规则可以让我们比较粗糙地简略地书写Makefile,这是由make所支持的。 3、 变量的定义。 在Makefile中我们要定义一系列的变量,变量一般都是字符串,这个有点你C语言中的宏,当Makefile被执行时,其中的变量都会被扩展到相应的引用位置上。 4、 文件指示。 其包括了三个部分,一个是在一个Makefile中引用另一个Makefile,就像C语言中的include一样;另一个是指根据某些情况指定Makefile中的有效部分,就像C中的预编译#if一样;还有就是定义一个多行的命令。 5、 注释。 Makefile中只有行注释,其注释是用“#”字符。 make命令 make工具的使用格式: make [命令选项] [命令参数] 通常使用make就可以了,make会按序查找名为GNUmakefile、Makefile和makefile作为编译指导文件;建议使用Makefile。 在make命令后面键入目标名即可建立指定的目标;如果不跟目标名则建立Makefile中定义的第一个目标。 make -f file 读入当前目录下的file文件作为Makefile; Make工作原理 make做的工作: 在执行gcc时会先检查依赖文件是否存在: 若不存在就先执行别的规则以生成缺少的依赖文件,最后生成相关的目标文件。 如果存在,并不急于执行gcc,而是先比较依赖文件与其对应源文件的时间戳。如果源文件较新的话,就会执行相应的规则来重新生成依赖文件和目标文件。否则就不会执行相应的gcc。 Make工作原理 1)如果工程没有编译过,那么所有C文件都要编译并被链接。 2)如果这个工程的某几个C文件被修改,那么只编译被修改的C文件,并链接目标程序。 3)如果这个工程的头文件被改变了,那么需要编译引用了这几个头文件的C文件,并链接目标程序。 目标的依赖关系 Makefile中的变量 变量的主要作用如下: 保存文件名列表:作为依赖文件的一些目标文件名出现在可执行文件的规则中,而在这个规则的命令行里同样包含这些文件并传递给gcc做为命令参数。如果使用一个变量来保存所有的目标文件名,则可以方便地加入新的目标文件而且不易出错。 保存可执行命令名:如果项目被用在一个非gcc的系统里,则必须将所有出现编译器名的地方改成用新的编译器名。但是如果使用一个变量来代替编译器名,那么只需要改变该变量的值。 保存编译器的参数:在很多源代码编译时,gcc需要很长的参数选项,在很多情况下,所有的编译命令使用一组相同的选项,如果把这组选项使用一个变量代表,那么可以把这个变量放在所有引用编译器的地方。当要改变选项的时候,只需改变一次这个变量的内容即可。 变量的定义和使用 Makefile中的变量是用一个文本串在Makefile中定义的,这个文本串就是变量的值。只要在一行的开始写下这个变量的名字,后面跟一个“=”号,以及要设定这个变量的值即可定义变量,下面是定义变量的语法: VARNAME=string 使用时,把变量用括号括起来,并在前面加上$符号,就可以引用变量的值: ${VARNAME} 变量一般都在Makefile的头部定义。按照惯例,所有的Makefile变量都应该是大写。如果变量的值发生变化,就只需要在一个地方修改,从而简化了Makefile的维护。 变量的其他定义方法: x := foo y := $(x) bar Makefile中常见自动变量 $* ??? ??? 不包含扩展名的目标文件名称 $+?? ???? 所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件 ???? $?? ??? ?? 第一个依赖文件的名称 $??? ?? ??? 所有时间戳比目标文件晚的依赖文件,并 以空格分开 $@?? ?? ?? 目标文件的完整名称 $^??? ??? ??所有不重复的依赖文件,以空格分开 Makefile中常见预定义变量 AR?? ?? ?? ? 归档维护程序的名称,默认值为ar AS?? ?? ?? ? 汇编程序的名称,默认值为as CC?? ?? ??? C编译器的名称,默认值为cc CPP?? ?? ? C预编译器的名称,默认值为$(CC) –E RM?? ?? ?? ? 文件删除程序的名称,默认值为rm –f ARFLAG
您可能关注的文档
最近下载
- 呼吸道职业暴露处理流程试题(附答案).docx VIP
- 项目部安全文明施工措施费投入计划表.docx VIP
- 【行业分析书】《2021-2035》杯纸行业发展战略及杯纸行业壁垒突破分析.pdf VIP
- 校本教材劳动学习实践.docx VIP
- 质量· 食品安全· HACCP· 环境· 职业健康安全五合一管理体系管理手册.pdf VIP
- 石文操作手册V1.0.docx VIP
- 石文操作手册.pdf VIP
- 教师信息技术教师岗面试真题题库参考答案和答题要点.docx VIP
- 《等差数列》(公开课)-全国一等奖-名师版精品课件.pptx VIP
- 【课堂新坐标(教师用书)高中英语 Unit 1 Period V Culture Corner & Bulletin Board课件 北师大版必修1.ppt VIP
文档评论(0)