1、“=”的作用
举例理解最快:
x =foo
y = $(x) bar
x = xyz
all:
echo $(y)
输出:
xyz bar
原因是为什么呢?为什么不是foo bar呢?
解释:
当执行make命令后makefile中变量展开;
原本应该如此 x=foo; y=foo bar; x =xyz
但实际是展开时x为 xyz, "="寻找的是变量最终的值;
y=$(x) bar 就变成了 xyz bar
x最终为 xyz
举例二:
x :=foo
y := $(x) bar
x := xyz
all:
echo $(y)
*输出:*foo bar
这又是什么原因呢??“=” 换成了 “:=”结果差很大;
解释:
:=的作用域取决于 当前变量解析时所处的位置替换,并不去最终的值;
因此当解析到y :=$(x) bar时,x的值为foo 替换后就是 foo bar
举例三:
x ?=foo
y := $(x) bar
x ?= xyz
all:
echo $(x)
echo $(y)
输出 :
foo
foo bar
首先有输出为 foo 证明执行 x?=foo
y 的值为 foo bar 证明第二句 也执行了;
那x ?= xyz 没执行吗
解释:是 这样的,?=是做了个判断,如果该变量已经有了值则不对它进行再次 赋值覆盖,如果没有值则进行赋值;
+=就相当于 java中字符串 连接 string A += B
A就是 A+B的内容;