Linux Makefile自动生成头文件依赖的过程中,中间文件 .d 的创建与更新

参考资料:
<Makefile自动生成头文件依赖>  http://www.cnblogs.com/lidabo/p/4928956.html
<跟我一起写Makefile> by 陈晧


初次编译时,.d 不存在:

    调用隐含规则生成 .d
    包含 .d(注意:该文件定义 .d 依赖于 .cpp .h,由于 .d 是新建文件,肯定不过时)
    从最终目标开始推导依赖关系链

后续编译时,.d 已存在:
    包含 .d(注意:该文件定义 .d 依赖于 .cpp .h)
    如果 .d 过时,再次调用隐含规则重新生成 .d,并重新包含
    从最终目标开始推导依赖关系链

以下用一个简化后的例子进行说明。

Makefile文件内容:

final: abc.obj
    @echo "【$@】V1=$(V1)"
%.d: %.cpp
    @echo "【隐含规则1】$^ --> $@"
    echo -e "V1=$$$$\n$*.obj $@: $*.cpp $*.h" > $@
%.obj: %.cpp
    @echo "【隐含规则2】$^ --> $@"
include abc.d

输入下列命令准备测试环境:
    touch abc.cpp abc.h

初始时abc.d不存在。输入命令:
    make

处理流程:
- 调用“隐含规则1”生成abc.d。注意在此规则的执行过程中,abc.d的依赖文件($^)为abc.cpp。
- 包含abc.d,其中定义了abc.d依赖abc.cpp abc.h,由于abc.d是新建文件,肯定不过时。
- 从最终目标开始推导依赖关系链并处理。

更新abc.h,然后再次make。命令如下:
    touch abc.h
    make

处理流程:
- 包含abc.d,其中定义了abc.d依赖abc.cpp abc.h。
- 由于abc.h已更新,导致abc.d过时,因此调用“隐含规则1”重新生成abc.d。注意虽然规则只列出.cpp,但其依赖文件($^)仍然为abc.cpp abc.h。
- 重新包含abc.d,这一点可以从变量V1发生了改变得到证明。
- 从最终目标开始推导依赖关系链并处理。
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值