zoukankan      html  css  js  c++  java
  • Makefile学习之通配符和自动变量($@、$<、$^)

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

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

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

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

      objects=*.c

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

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

        objects := $(wildcard *.o);

        wildcard是Makefile中的关键字;

    3.Makefile中的自动变量

      $@  :表示所在的规则中的所有的目标。

        $^    : 生成目标($@)时所有的依赖集合, 以空格分隔。

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

      $<   :所有的依赖集合中的第一个依赖

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

    all: test1    test2
        @echo "11" $@                                  
        @echo "22" $^
        @echo "33" $<
    
    test1:
        @echo "test1"
    test2:
        @echo "test2"

     输出:

    test1
    test2
    11 all           //目标
    22 test1 test2    //生成目标所有的依赖集合
    33 test1        

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

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

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

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

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

  • 相关阅读:
    最近看到C#里面的抽象类和接口,还有索引器。
    Memcached服务端自动启动
    python操作MySQL数据库
    Linux开放端口
    关于数组的几道面试题
    这群超酷的开发者,是如何轻松搞定软件开发?
    五分钟开发好你的第一个人工智能应用
    Case Study: 技术和商业的结合点在哪里?
    【江湖趣事】话说开源界和微软的那些往日恩怨
    评微软收购GitHub
  • 原文地址:https://www.cnblogs.com/weiyouqing/p/8599971.html
Copyright © 2011-2022 走看看