Makefile学习笔记(4)—— 多目标依赖于同一文件,静态模式,自动生成依赖性

本文介绍了Makefile的三个高级特性:4.1多目标,4.2静态模式,以及4.3自动生成依赖性。在多目标中,展示了如何合并相同命令的目标规则。静态模式允许更方便地定义多目标规则,通过`%.o:%.c`这样的模式匹配。自动依赖性利用C编译器的`-M`或`-MM`选项生成头文件依赖,避免手动维护Makefile。文章还给出了实际示例和具体操作步骤。
摘要由CSDN通过智能技术生成

4.1多目标

Makefile 的规则中的目标可以不止一个,其支持多目标,有可能我们的多个目标同时依赖于一个文件,并且其生成的命令大体类似。于是我们就能把其合并起来。当然,多个目标的生成规则的执行命令是同一个,这可能会可我们带来麻烦,不过好在我们的可以使用一个自动化变量“$@”(关于自动化变量,将在后面讲述),这个变量表示着目前规则中所有的目标的集合,这样说可能很抽象,还是看一个例子吧。

big output littleoutput :text.g

      generate text.g -$(subst output,,$@)>$@

这个等价于:

     bigoutput :text.g

           generate text.g -big >bigoutput 

    littleoutput :text.g

           generate text.g -little >littleoutput
ps:这些是书上的内容,不太清楚这个的运用场景,有大佬的请指点下。

 

4.2静态模式

静态模式可以更加容易地定义多目标的规则,先看下静态规则的语法

<targets...>:<target-pattern>:<prereq-patterns...>
        <commands>

targets 定义了一系列的目标文件,可以有通配符。是目标的一个集合。
target-parrtern 是指明了 targets 的模式,也就是的目标集模式。
prereq-parrterns 是目标的依赖模式,它对 target-parrtern 形成的模式再进行一次依赖目标的定义。

假如<target-parrtern>定义成“%.o”,意思是我们的集合中都是以“.o”结尾的,而如果我们的<prereq-parrterns>定义成“%.c”,意思是对
<target-parrtern>所形成的目标集进行二次定义,其计算方法是,取<target-parrtern>模式中的“%”(也就是去掉了[.o]这个结尾),并为其加上[.c]这个结尾,形成的新集合。

所以,我们的“目标模式”或是“依赖模式”中都应该有“%”这个字符,如果你的文件名中有“%”那么你可以使用反斜杠“\”进行转义,来标明真实的“%”字符。

还是用之前的测试小例子

项目结构图如下

makefile文件内容如下

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值