学写makefile一点心得.docxVIP

  1. 1、本文档共3页,可阅读全部内容。
  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文档。上传文档
查看更多
学写makefile一点心得

学写makefile一点心得var=-Wall–g CC=gccCC+=$(var)str=${wildcard *.c}obj=${patsubst %.c,%.o,$(str)}xxx:$(obj)$(CC) $^ -o $@$(obj):%.o:%.c$(CC) -c $^ -o $@clean:@$(RM) xxx$(obj)这是在用makefile编写的一个程序。在当前makefile的目录中,有四个文件,分别是a.c、b.c、file_inc.h和main.c四个文件,其中a.c、b.c、file_inc.h三个是一起构成的源程序,main.c是另外的,它们之间不关联。str=$(wildcard *.c)是一个函数来表示,其函数原型为:$(wildcard PATTERN)函数名称:获取匹配模式文件名函数—wildcard函数功能:列出当前目录下所有符合模式“PATTERN”格式的文件名。返回值:空格分割的、存在当前目录下的所有符合模式“PATTERN”的文件名。函数说明:“PATTERN”使用shell可识别的通配符,包括“?”(单字符)、“*”(多字符)等。obj=$(patsubst %.c,%.o,$(str))这也是一个函数,其原型为:$(patsubst PATTERN,REPLACEMENT,TEXT)函数名称:模式替换函数—patsubst。函数功能:搜索“TEXT”中以空格分开的单词,将符合模式“TATTERN”替换为“REPLACEMENT”。参数“PATTERN”中可以使用模式通配符“%”来代表一个单词中的若干字符。如果参数“REPLACEMENT”中也包含一个“%”,那么“REPLACEMENT”中的“%”将是“TATTERN”中的那个“%”所代表的字符串。在“TATTERN”和“REPLACEMENT”中,只有第一个“%”被作为模式字符来处理,后续的作为字符本上来处理。在两个参数中当使用第一个“%”本是字符本身时,可使用反斜杠“\”对它进行转义处理(转义处理的机制和使用静态模式的转义一致)。返回值:替换后的新字符串。函数说明:参数“TEXT”单词之间的多个空格在处理时被合并为一个空格,但前导和结尾空格忽略。另外还要注意,在函数参数之间不能有空格,不然,编译器会报警,编译通不过。示例:$(patsubst %.c,%.o,x.c.c bar.c)把字串“x.c.c bar.c”中以.c结尾的单词替换成以.o结尾的字符。函数的函数的返回结果是“x.c.o bar.o”clean:@$(RM) xxx$(obj)该语句是把文件xxx 和$(obj)删除,RM是文件删除程序的名字,默认值为rm -f (非交互模式的删除操作,忽略不存在的文件)Makefile规则Makefile的规则包括目标体、依赖文件及其间的命令语句,是Make进行处理的依据。Makefiler中的一条语句就是一条规则。1、隐式规则隐式规则能够告诉make怎样使用传统的技术完成任务,这样,当用户使用它们就不必详细指定编译的具体细节,而只需把目标文件列出即可。Make会自动搜索隐式规则目录来确定如何生成目标文件2、伪目标如上图所示,其中all就是一个伪变目标。它里面不只一个目标文件。而下面的$(obj):%.o:%.c就是用模式规则分别列出各个互不相关的目标文件。3、函数在这个在里面,也可以用函数来处理信息,例如我们的上面的那个例子,里面有两个函数来处理。

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档