最容易混淆的是 =和:=, 我们先来看看makefile:
- x = hello
- y = $(x)
- x = world
- test1: test1.cpp
- @echo $(y)
- x = hello
- y := $(x)
- x = world
- test1: test1.cpp
- @echo $(y)
因为=其实类似于C++中的引用, 相当于y和x绑定了, 所以在echo的时候, 值为world
而:=其实类似于C++中的赋值, 所以在echo的时候, 值为hello. 在makefile中, 强烈建议使用:=进行复制。
y?=x是什么呢? 其实很好理解, 它的意思是: 如果y没有赋值过, 那就赋值。 如果赋值过, 那本次就不赋值了。
y+=x是什么呢? 很好理解, 其实就是C++中的+=, 相当于累加。
这些东西本来很简单, 但我发现, 有很多地方没讲清楚, 所以来唠叨一下。