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

参考自: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 函数执行的次数比你想像的多得
多。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值