39、深入理解 Makefile 规则与变量

深入理解 Makefile 规则与变量

1. Make 规则命令部分的特性

Make 规则的命令部分并非 shell 脚本。当 Make 调用规则来构建目标时,规则命令部分的每一行会在单独的 shell 实例中分别执行。因此,要确保任何命令都不依赖于前一行的副作用。

例如,以下命令不会在 src 子目录中运行 etags

TAGS:
        cd src/
        etags *.c

在构建 TAGS 时,Make 先在当前目录下运行 cd src/ ,该命令退出后,又在新的 shell 中、当前目录下运行 etags *.c

若要让多个命令在同一个 shell 中运行,有两种方法:
- 将它们放在一行,用分号分隔。
- 添加反斜杠,使其在逻辑上处于同一行。

示例如下:

TAGS:
        cd src/    ;\
        etags *.c

在大型项目中,让多个命令在同一 shell 中运行还能加快处理速度。

2. 模式规则

2.1 模式规则的基本概念

模式规则可经济地描述具有重复模式的情况。例如, circle.o

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值