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的内容;