第一阶段:
make读入所有的makefile,以及makefile中所包含的其他makefile
make分析并获取变量名,变量值,隐式规则和显示规则
构建所有目标的关系树,以及他们的先决条件
第二阶段:
接着就是执行命令了(基于第一阶段的关系树,确定需要重新构建的目标)
理解make处理makefile的两个阶段对于熟练地编写makefile非常重要。
makefile中的语句存在立即展开和延迟展开两种类别。
立即展开是在第一阶段就被展开。变量和函数就是立即展开的。
延迟展开指并不在第一阶段展开,而是在第二阶段。
对于不同语句,make有不同的展开策略---->
1)赋值相关:
立即展开 = 延迟展开
立即展开 ?= 延迟展开
立即展开 := 立即展开
立即展开 += 立即展开或延迟展开(取决于变量之前变量的赋值形式)
2)条件语句:
对于条件语句,make都是立即展开,这包括ifdef,ifeq,ifndef和ifneq,因为自动变量都是在规则所对应的命令块中被设置的,而这一过程发生在第二阶段,即自动变量是延迟展开的,所以自动变量在条件语法中不能使用。如果非要使用,只能用shell的条件语法,而不是make