= 是最基本的赋值
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值
makefile中“=”和“:=”的区别到底有什么区别,看两个简单的makefile
第一个
x = foo
y = $(x) bar
x = xyz
all:
@echo "$(y)"
执行make后,得到结果
xyz bar
第二个
x := foo
y := $(x) bar
x := xyz
all:
@echo "$(y)"
执行make后,得到结果
foo bar
可以看到使用“:=”使用的是赋值时的值,也就是在y := $(x) bar时x的值,此时x的值为bar,所以y的值为 foo bar。
使用“=”,使用的是最终的值,也就是在y = $(x) bar赋值时,使用的是最后的x的值,为xyz,所以最后的y值为xyz bar。