嵌套执行

文章目录

嵌套执行


在实际的项目工程中,往往把 Makefile 文件分解为多个子 Makefile 文件,并放置到每一个子目录中,每个子 Makefile 文件负责所在目录下源文件的编译工作。

  1. Make 工程管理器会首先读取程序目录下的 Makefile 文件 (总控 Makefile);
  2. 然后去读取各个子目录下的子 Makefile 文件。
    这个过程称之为 Make 的嵌套执行
    嵌套执行的使用方法为:cd 子目录 && $(MAKE) 或者为 $(MAKE) -c 子目录
    例如,首先在 /home/b 目录下新建一个子 Makefile,如下所示:
// 目录结构
|-- home/
    |-- Makefile
    |-- b/
        |-- Makefile
        |-- b.c
# /home/b

b.o : b.c
    cc -c -o b.o b.c

然后修改 /home 目录下的总控 Makefile ,如下所示:

VPATH = /home/b
obj = a.o b.o

.PHONY = all
all : test $(obj)

test : $(obj)
    cc -o test a.o b/b.o

b.o : b.c
    cd b && make

执行指令,结果如下:

# make
cc -c -o a.o a.c // 生成目标文件 a.o
cd b && make
make[1] : Entering directory `/home/b`
cc -c -o b.o b.c // 生成目标文件 b.o
make[1] : Leaving directory `/home/b`
cc -o test a.o b/b.o // 生成目标文件 test

可以看到,Make 产生 a.o 之后会进入 home/b 目录读取子目录 Makefile,编译产生 b.o 之后退出该目录。
使用 嵌套编译 时,上层 Makefile 把编译任务下发给各个下层 Makefile 进行处理,最后汇总各个子结果。

总控 Makefile 中的变量可以通过 export 变量的方式传递到各个子 Makefile 中,但不会覆盖子 Makefile 中的变量。也可以通过 unexport 变量的方式不让变量传递到各个子 Makefile 中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值