简单实例,makefile自动依赖(二)

这篇博客介绍了如何在Makefile中利用cc的-M或-MM参数自动生成依赖关系,避免手动维护头文件的依赖。文章详细解释了wildcard、join、patsubst等Makefile函数的用法,并展示了如何在不同子目录的Makefile中应用这些技巧来构建正确的目标文件依赖。此外,还提到了sinclude指令以及Makefile在包含.d文件时的处理方式。

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

参考自:http://blog.chinaunix.net/uid-20316928-id-3395996.html

《跟我一起学makedfile》 《GUN makefile……》


上一篇中发现修改了头文件,但是执行make后不会自动重新编译,

研究发现是因为没有头文件的依赖,最傻的加依赖方法就是在编译的时候头文件一块加进去。

那样子的话总不能每增加一个头文件都要去改一次makefile,上网一搜发现可以自动生成依赖文件,所以有了这篇文章。


有错的地方欢迎指出。互相交流,共同进步。



首先上编译前的源码树:



顶层makefile:


主要讲一下makefile中使用的几个函数:

第7行:wildcard

返回的值是include目录下面的所有的.h文件

第11行:join

$(join aaa bbb , 111 222 333)返回值是“aaa111 bbb222 333”

第12行:patsubst:

$(patsubst %.c,%.o,x.c.c bar.c)
把字串“x.c.c bar.c”符合模式[%.c]的单词替换成[%.o],返回结果是“x.c.o bar.o”

第22行:foreach,

names := a b c d
files := $(foreach n,$(names),$(n).o)
上面的例子中,$(name)中的单词会被挨个取出,并存到变量“n”中,“$(n).o”每次
根据“$(n)”计算出一个值,这些值以空格分隔,最后作为 foreach 函数的返回,所以,
$(files)的值是“a.o b.o c.o d.o”。

shell,

它的参数应该就是操作系统 Shell 的命令,它和反引号“`”是相同的功能。

注意,这个函数会新生成一个 Shell 程序来执行命令,所以你要注意其运行性能,如果你的
Makefile 中有一些比较复杂的规则,并大量使用了这个函数,那么对于你的系统性能是有
害的。特别是 Makefile 的隐晦的规则可能会让你的 shell 函数执行的次数比你想像的多得
多。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值