MakeFile基础.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
环境变量MAKEFILES 如果你的当前环境中定义了环境变量MAKEFILES,那么,make会把这个变量中的值做一个类似于include的动作。 和include不同的是,从这个环境变中引入的Makefile的“目标”不会起作用,如果环境变量中定义的文件发现错误,make也会不理。 建议不要使用这个环境变量 Make的工作方式 1. 读入所有的Makefile 2. 读入被include的其它Makefile 3. 初始化文件中的变量 4. 推导隐晦规则,并分析所有规则 5. 为所有的目标文件创建依赖关系链 6. 根据依赖关系,决定哪些目标要重新生成 7. 执行生成命令 * * * * MAKEFILE基础 研发部 (2009-03-24) 培训安排 1. 预备知识(GCC) 2. makefile的介绍 3. makefile的总述 一.预备知识-GCC 什么是GCC GNU C Compiler GNU Compiler Collection 交叉编译器:arm-linux-gcc 示例一:Hello world #include stdio.h int main(void) { printf(Hello World\n); return 0; } Gcc hello.c 编译和链接 源文件(.c)-预处理文件(.i)-汇编代码(.s)-目标文件(.o)-可执行文件(.elf) -E;-S;-c;-o Compile:语法的正确,函数,变量声明的正确 Link:根据头文件,声明找寻函数等的实现 示例二 Fun1.c:两个整型相加 Fun2.c:两个整型相乘 Main.c:打印两个整型相加相乘的结果 Gcc –c fun1.c Gcc –c fun2.c Gcc –c main.c Gcc –o main main.o fun1.o fun2.o 二.MAKEFILE介绍 Makefile概述 一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中。 只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。 Makefile:自动脚本(类似于SHELL) Make:是一个命令工具,是一个解释makefile中指令的命令工具。 Makefile介绍 1. 如果工程没有编译过,所有C文件都必须要编译并被链接。 2. 如果工程中的某几个C文件被修改,只需编译被修改的C文件,并链接目标程序。 3. 如果工程的头文件改变了,需编译引用这个头文件的C文件,并链接目标程序。 Makefile规则 TARGET…:PREREQUISITES… COMMAND … TATGET:目标文件,可执行文件,标签 PREREQUISITES:生成TARGET所需要的文件。 COMMAND:任意的SHELL命令。 示例三 一个工程有3个头文件,8个C文件,根据前面的规则和格式,编写MAKEFILE。 Makefile(1) 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 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 Makefile(2) 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.o display.o \ insert.o search.o files.o utils.o 示例三解释 1. “\”是换行符,增强可读性。执行make生成可执行文件edit;执行 make clean删除执行文件和中间目标文件。 2. 本例中,目标文件有两种

文档评论(0)

飞扬的岁月 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档