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的通用特性和多个权威来源的资料整理得出,希望能对您有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值