Makefile编程:4种赋值差异
Makefile中的变量赋值方式主要有以下几种,每种方式在变量值的求值时机和效果上有所不同:
1. 简单赋值(:=
)
-
特点:使用
:=
进行赋值时,表达式在定义时立即求值,不再依赖于变量的后续更改。这种赋值方式类似于C语言中的赋值操作。 -
示例:
VAR := value
在这个例子中,
VAR
被赋值为value
,且这个值在定义时就确定了,不会因后续变量值的改变而改变。
2. 递归赋值(=
)
- 特点:当使用
=
进行赋值时,右侧的表达式在变量实际被使用时才进行求值(展开)。这意味着如果变量的值依赖于其他变量的值,而这些变量的值在后续可能会发生变化,那么使用=
赋值的变量在展开时会反映这些变化。 - 示例:
在这个例子中,VAR1 = foo VAR2 = $(VAR1)bar VAR1 = new_value
VAR2
的值在最终使用时才会展开,因此它最终的值是new_valuebar
,而不是foobar
。
3. 条件赋值(?=
)
- 特点:使用
?=
进行赋值时,如果变量尚未定义或值为空,则进行赋值;如果变量已经被定义(无论其值是否为空),则不进行赋值。 - 示例:
如果VAR ?= default_value
VAR
在之前没有被定义,或者其值为空,则VAR
会被赋值为default_value
。
4. 追加赋值(+=
)
- 特点:使用
+=
进行赋值时,会在原变量值之后加上一个新值,原变量值与新值之间由空格分隔。这种赋值方式常用于向变量追加额外的值。 - 示例:
在这个例子中,VAR := foo VAR += bar
VAR
的值最终会是foo bar
。
举例证明
- 执行如下代码:
var0 := 000
var1 :=$(var0)-111
var2 ?=$(var0)-222
var3 =$(var0)-333
var4 +=$(var0)-444
all:
@echo $(var1)
@echo $(var2)
@echo $(var3)
@echo $(var4)
show1:
$(eval var0 := 00-)
@echo $(var1)
show2:
$(eval var2 ?= 222)
@echo $(var2)
show3:
$(eval var0 := 00-)
@echo $(var3)
show4:
- 结果如下:
hs@hs-virtual-machine:~/test$ make
000-111
000-222
000-333
000-444
hs@hs-virtual-machine:~/test$ make show1
000-111
hs@hs-virtual-machine:~/test$ make show2
000-222
hs@hs-virtual-machine:~/test$ make show3
00--333
hs@hs-virtual-machine:~/test$ make show4
000-444 -44
总结
Makefile中的变量赋值方式各有特点,选择合适的赋值方式对于编写清晰、高效的Makefile至关重要。简单赋值(:=
)适用于在定义时就需要确定变量值的情况;递归赋值(=
)适用于变量值依赖于其他变量且这些变量的值可能在后续发生变化的情况;条件赋值(?=
)适用于为变量提供默认值的情况;追加赋值(+=
)则适用于需要向变量追加额外值的情况。
以上信息基于Makefile的通用特性和多个权威来源的资料整理得出,希望能对您有所帮助。