头文件和源文件在不同目录情况下 Makefile自动推导依赖关系的实现

本文介绍了如何在头文件和源文件位于不同目录的情况下,使用Makefile自动推导并处理依赖关系。通过修改Makefile,结合gcc的-MM选项生成.d文件,再利用include命令在编译时引入这些依赖关系。当工程结构变得复杂,头文件和源文件分布在不同目录时,需要调整Makefile的编译规则,确保正确处理跨目录依赖。最终提出了一种简化方法,通过CXXFLAGS添加INCLUDE路径,避免在.d文件中定制编译规则。

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

参考 跟我一起写Makefile http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=408225&extra=&authorid=10610714&page=1


首先回顾《跟我一起写Makefile》里有一节 自动生成依赖性。利用gcc中的一个编译选项 -MM,得到源文件的依赖文件,然后将其写入一个.d文件,每次make命令执行时,利用include 命令将.d文件内的依赖关系包含进makefile里,这样每个源文件是否需要重新编译可根据.d依赖文件的情况判定。

    %.d: %.c
            set -e; rm -f $@; \
             $(CC) -M $(CPPFLAGS) $< >; $@.$$$$; \
             sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
             rm -f $@.$$$$

这段是《跟我一起写Makefile》里生成依赖文件.d的代码。

set -e ; rm -f $@; 第一句将shell设置为当命令输出非0时则退出,第二句删除原有.d文件

$(CC) -M $(CPPFLAGS) $< >; $@.$$$$;
该命令对源文件生成 依赖文件,并将其保存为$@.$$$$,后面的一串$$$$表示文件的后缀是一个随机码(听说是表示进程号),反正是为了不可能与其他文件重复,只是作为一个临时文件而已

sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@;
该命令是利用shell里的sed命令中的 sed
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值