Makefile 学习小结

一些MakeFile的语法小结:
赋值号:
= 赋值
:= 表示以前的赋值都不要,从这次赋值开始算。相当于overwrite
+= 依次加上,相当于append
?= 跟C语言里面的条件赋值意思一样

Makefile 常用的环境变量有下面这些:

$*:不包含扩展名的目标文件名称
$<:第一个依赖文件名称
$?:所有时间戳比目标文件晚的依赖文件
$@:目标文件完整名称
$^:所有不重复的依赖文件

make 参数:
-f: 指定某文件为Makefile
-C: 调用子级 Makefile
-j: 使用并行编译,后面跟CPU的个数

/etc/ld.so.conf 和 /etc/ld.so.conf.d 程序员添加动态库的脚本位置 (其中/etc/ld.so.conf.d是放置一些子配置文件)
/etc/ld.so.cache 动态库的缓存,对上面两个配置文件生效
/sbin/下的ldconfig可以配置ld.so.cache
如果用export LD_LIBRARY_PATH=xxx 只会把xxx加到/etc/ld.so.cache里面去,不会加到/etc/ld.so.conf 和 /etc/ld.so.conf.d

make的工作方式
原文链接
https://seisman.github.io/how-to-write-makefile/introduction.html
GNU的make工作时的执行步骤如下:(想来其它的make也是类似)

  1. 读入所有的Makefile。
  2. 读入被include的其它Makefile。
  3. 初始化文件中的变量。
  4. 推导隐晦规则,并分析所有规则。
  5. 为所有的目标文件创建依赖关系链。
  6. 根据依赖关系,决定哪些目标要重新生成。
  7. 执行生成命令。

1-5步为第一个阶段,6-7为第二个阶段。第一个阶段中,如果定义的变量被使用了,那么,make会把其展开在使用的位置。但make并不会完全马上展开,make使用的是拖延战术,如果变量出现在依赖关系的规则中,那么仅当这条依赖被决定要使用了,变量才会在其内部展开。
个人觉得5,6步用到了拓扑排序(BFS)。
当然,这个工作方式你不一定要清楚,但是知道这个方式你也会对make更为熟悉。有了这个基础,后续部分也就容易看懂了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值