Makefile中几个赋值运算符

在Makefile中经常看见这几个赋值运算符(“=”,“:=”,“?=”,“+=”)

新建一个Makefile,内容如下:

ifdef aa

    var="hello world"

endif

ifeq ($(bb),define)

    var ?= "hello world 1"

endif

ifeq ($(bb),define1)

    var +="bb"

endif

ifeq ($(bb),define2)

    var := "hello world is over"

endif

all:

    @echo $(var)

输入一下命令:

make aa=true bb=define 输出:hello world

make aa=true bb=define1 输出:hello worldbb

make aa=true bb=define2 输出:hello world is over

make aa=bb=define  输出:hello world 1

make aa=bb=define1 输出:bb

make aa=bb=define2 输出:hello world is over

 

从输出可以看到他们的区别

"=" :是最基本的赋值运算

":=":是覆盖之前的值

"?=":是如果没有被赋值过的就赋予等号后面的值

"+=":是添加等号后面的值

 

注:

make会将整个Makefile展开,再决定变量的值。也是说,变量的值将会是整个Makefile最后被指定的值。

“=”的例子1:

 x=foo

y=$(x)bar

x=xyz

在上面例子中y的值将是xyzbar,而不是foobar。

“:=”的例子2:

“:=”表示变量的值决定于它在Makefile中的位置,而不是整个Makefile展开后的最终值。

x:=foo

y:=$(x)bar

x:=xyz

在例子中,y的值将会输出foobar,而不是xyzbar了。

 

转载于:https://my.oschina.net/zhucq/blog/734619

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值