Makefile学习之通配符和自动变量

本文详细介绍了Makefile中的通配符使用方法,包括*、?、[...]等,并解释了如何在变量中正确应用这些通配符。此外,还深入探讨了Makefile中的自动变量,如$@、$<、$^等的含义与应用场景。

规则中的通配符 “*” ,“?” ,“ [...]”, " % " , " wildcard "

1.“*”  *.c表示所有后缀为.C的文件;

   如果文件中用到通配符,使用“\*”;

2.通配符在变量中的使用;

  objects=*.c

  注意:这里的通配符就是用在变量中的,不过,objects的值就是“*.o”,并不会展开;

  如果希望展开的话,可以这么使用:

    objects := $(wildcard *.o);

    wildcard是Makefile中的关键字;

3.Makefile中的自动变量

  $@  :表示的是$@所在的规则中的所有的目标文件集。

  $<   :依赖目标中的第一个目标名字。

    如果依赖目标是以模式(即"%")定义的,那么"$<"将是符合模式的一系列的文件集。注意,其是一个一个取出来的。 

  $^    : 所有的依赖目标的集合。以空格分隔。

    如果在依赖目标中有多个重复的,那个这个变量会去除重复的依赖目标,只保留一份。

  $? : 所有比目标新的依赖目标的集合。以空格分隔。   

  $%   :仅当目标是函数库文件中,表示规则中的目标成员名。

      例如,如果一个目标是"foo.a(bar.o)",那么,"$%"就是"bar.o","$@"就是"foo.a"。

      如果目标不是函数库文件(Unix下是[.a],Windows 下是[.lib]),那么,其值为空。 

  $+  :这个变量很像"$^",也是所有依赖目标的集合。只是它不去除重复的依赖目标。

 

转载于:https://www.cnblogs.com/weiyouqing/p/8599971.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值