makefile自动化变量分析和总结.docxVIP

  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文档。上传文档
查看更多
makefile 自动化变量 首 先 说 明 一 下 makefile 学 习 比 较 好 的 网 址 , 跟 我 一 起 写 makefile: /index.php?title=%E8%B7%9F%E6%88%91%E4%B8%80%E8%B5%B7%E 5%86%99Makefilevariant=zh-cn $@ 代表规则中的目标文件名。如果目标是一个文档(Linux 中,一般称.a 文件为文档),那么它代表这个文档的文件名。在多目标的模式规则中,它代表的是哪个触发规则被执行的目标文件名。 $% 规则的目标文件是一个静态库文件时,代表静态库的一个成员名。例如,规则的目标是“foo.a(bar.o)”,那么,“$%”的值就为“bar.o”,“$@”的值为“foo.a”。如果目标不是函数库文件, 其值为空。 $ 规则的第一个依赖文件名。如果是隐含规则,则它代表通过目标指定的第一个依赖文件。 $? 所有比目标文件更新的依赖文件列表,空格分割。如果目标是静态库文件名,代表的是库成员(.o 文件)的更新情况。 $^ 规则的所有依赖文件列表,使用空格分隔。如果目标是静态库文件名,它所代表的只能是所有库成员(.o 文件)名。一个文件可重复的出现在目标的依赖中,变量“$^”只记录它的一次引用情况。就是说变量“$^”会去掉重复的依赖文件。 $+ 类似“$^”,但是它保留了依赖文件中重复出现的文件。主要用在程序链接时,库的交叉引用场合。 $* 在模式规则和静态模式规则中,代表“茎”。“茎”是目标模式中“%”所代表的部分(当文件名中存在目录时,“茎”也包含目录(斜杠之前)部分)。例如:文 件“dir/a.foo.b”,当目标的模式为“a.%.b”时,“$*”的值为“dir/a.foo”。“茎”对于构造相关文件名非常有用。 自动化变量“$*”需要两点说明: ? 对于一个明确指定的规则来说不存在“茎”,这种情况下“$*”所代表的值发生变化。此时,如果目标文件名带有一个可识别的后缀,那么“$*”表示文件中除 后缀以外的部分。例如:“foo.c”则“$*”的值为:“foo”,因为.c 是一个可识别的文件后缀名。GUN make 对明确规则的这种奇怪的处理行为是为了和其它版本的 make 兼容。通常,在除静态规则和模式规则以外,明确指定目标文件的规则中避免使用这个变 量。 ? 当明确指定文件名的规则中目标文件名包含不可识别的后缀时,此变量为空。 自动化变量“$?”在显式规则中也是非常有用的,规则中可以使用它来指定只对更新的依赖文件进行操作。例如,函数库文件“libN.a”,它由一些.o 文件组成。如下的规则实现了根据变化的.o 文件更新库文件: lib: foo.o bar.o lose.o win.o ar r lib $? 上述列出的自动量变量中。其中有四个在规则中代表一个文件名( $@、$、$%、$*)。而其它三个的在规则中代表一个文件名的列表。GUN make 中,还可以通过这七个自动化变量来获取一个完整文件名中的目录部分或者具体文件名,需要在这些变量中加入“D”或者“F”字符。这样就形成了一系 列变种的自动环变量。这些变量在以前版本的 make 中使用,在当前版本的 make 中,可以使用“dir”或者“notdir”函数来实现同样的功能。 $(@D) 代表目标文件的目录部分(去掉目录部分的最后一个斜杠)。如果“$@”是“dir/foo.o”,那么“$(@D)”的值为“dir”。如果“$@”不存在斜杠,其值就是“.”(当前目录)。注意它和函数“dir” 的区别! $(@F) 目标文件的完整文件名中除目录以外的部分(实际文件名)。如果“$@”为“dir/foo.o”,那么 “$(@F)”只就是“foo.o”。“$(@F)”等价于函数“$(notdir $@)”。 $(*D) $(*F) 分别代表目标“茎”中的目录部分和文件名部分。 $(%D) $(%F) 当以如“archive(member)”形式静态库为目标时,分别表示库文件成员 “member” 名中的目录部分和文件名部分。它仅对这种形式的规则目标有效。 $(D) $(F) 分别表示规则中第一个依赖文件的目录部分和文件名部分。 $(^D) $(^F) 分别表示所有依赖文件的目录部分和文件部分(不存在同一文件)。 $(+D) $(+F) 分别表示所有依赖文件的目录部分和文件部分(可存在重复文件)。 $(?D) $(?F) 分别表示被更新的依赖文件的目录部分和文件部分。 需要说明的是:在讨论自动化变量时,为了和普通变量(如:“CFLAGS”)的区别,我们直接使用了“$”的形式。这只是仅仅为了和普通变量区 别,没有别的目的。其实对于自动环变量和普通变量一样,代表规则第一个依赖文件名的变量

文档评论(0)

hao187 + 关注
官方认证
文档贡献者

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

认证主体武汉豪锦宏商务信息咨询服务有限公司
IP属地上海
统一社会信用代码/组织机构代码
91420100MA4F3KHG8Q

1亿VIP精品文档

相关文档