当前位置: 代码迷 >> 综合 >> Makefile 中=和:= 的区别
  详细解决方案

Makefile 中=和:= 的区别

热度:92   发布时间:2023-12-08 16:08:13.0
= 是最基本的赋值
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值
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。