多目录Makefile编写

这篇博客探讨了在大型工程中管理多目录编译的问题。传统的Makefile编写方式存在新模块添加繁琐、无法并行编译和依赖关系不明确等问题。作者提出了一种改进的Makefile方案,通过定义dirs变量和利用$(MAKE)命令实现自动化编译,并使用-j选项进行并行编译,解决了上述问题。实验表明,在多核CPU环境下,设置并行编译数量为核数+1可以提升效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

编译过大型工程的朋友应该都知道,当多个模块要协作编译的时候,通常要进入一个个目录去编译,所以,makefile可能如下所示:

all:
    cd dir1;make all;
    cd dir3;make all;
    cd dir2;make all;
clean:
    cd dir1;make clean;
    cd dir3;make clean;
    cd dir2;make clean;

当然,我们也可以用makefile自身的特性,即 make all/clean -C dir1来进行编译,但是实际上两种写法都避免不了3个问题:
1.当新加入一个模块的时候,要写入两句代码,一句是all,一句是clean,很容易漏掉。
2.没有办法进行并行编译。因为很可能这些模块之间是不互相依赖的,而并行编译可以极大的提高速度(如果你受得了make那蜗牛般的速度的话,可以无视掉这一条)
3.依赖关系不明显(可以看出是dir2依赖与dir3,但是没有明确的指出)

那么解决方法是怎样呢?有这样一个makefile

dirs = dir1 /
       dir2 /
       dir3
.PHONY: all clean $(dirs)
all: $(dirs)
clean: $(dirs)
$(dirs):
    $(MAKE) -j2 -C $@ $(MAKECMDGOALS)
dir2:dir3

在这个makefile的同级目录有3个目录,分别为dir1,dir2,dir3,其中每个目录的makefile就不说了,大家看图应该能明白,执行make后,结果如下:

QQ截图未命名

对于并行编译的-j选项,其实我也不是很清楚,不过同事说如果cpu是多核,那么开核数+1的并行编译数是最好的,据说测试过确实如此,所以我也就没有在深究了。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值