Makefile中几种赋值=, :=, ?=, +=

=  延时变量,只有被使用时才展开定义 。注:赋值后,在没有使用该变量之前,如果改变等号右边的值,则等号左边的变量的值被改变
:= 立即变量,定义时的赋值立即有效。注:赋值后,等号右边的表达式内容变化不会影响冒号右边的变量值 
?= 条件变量,当变量为空时才赋值 
+= 追加赋值

示例:

VAR_A=abc
VAR_B=$(VAR_A) 222
VAR_C:=$(VAR_A)
VAR_A=def
#VAR_B的值会改变为def,而VAR_C的值还是为abc

VAR_A:=$(VAR_B)222
VAR_B=$(VAR_A)
#由于一开始VAR_B没有值,所以VAR_A的值为222,VAR_B的值为222

VAR_D=111
VAR_D?=000
#VAR_D的值仍为111

VAR_E=file1.c
VAR_E+= file2.c
#VAR_E最后的值为file1.c file2.c
#等价于:
VAR_E=$(VAR_E) file2.c

参考自:https://blog.csdn.net/u011676475/article/details/72828603

猜你喜欢

转载自blog.csdn.net/weixin_41937674/article/details/82954348