Makefile 中:= ?= += =的区别

本文详细解析了Makefile中的不同变量赋值方式,包括基本赋值“=”,覆盖赋值“:=”,条件赋值“?=”及追加赋值“+=”的区别,并通过实例演示了这些赋值方式如何影响变量的最终值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.他们的区别如下:

“=”: 最基本的赋值

:= ”:覆盖之前的值
?= ”:如果没有被赋值过就赋予等号后面的值

+=”: 添加等号后面的值


2.比如新建一个Makefile内容如下:

ifdef DEFINE_VRE
	VRE = “Hello World!”
endif

ifeq ($(OPT),define)
	VRE ?= “Hello World! First!”
endif

ifeq ($(OPT),add)
	VRE += “Kelly!”
endif

ifeq ($(OPT),recover)
	VRE := “Hello World! Again!”
endif

all:
	@echo $(VRE)
敲入以下make命令:
make DEFINE_VRE=true OPT=define 输出:Hello World!
make DEFINE_VRE=true OPT=add 输出:Hello World! Kelly!
make DEFINE_VRE=true OPT=recover  输出:Hello World! Again!
make DEFINE_VRE= OPT=define 输出:Hello World! First!
make DEFINE_VRE= OPT=add 输出:Kelly!
make DEFINE_VRE= OPT=recover 输出:Hello World! Again!


3.“=”和“:=”的区别如下

 (1)“=”
      make会将整个makefile展开后,再决定变量的值。也就是说,变量的值将会是整个makefile中最后被指定的值。看例子:   

     x = foo
     y = $(x) bar
     x = xyz
      在上例中,y的值将会是 xyz bar ,而不是 foo bar 。
   (2)“:=”
      “:=”表示变量的值决定于它在makefile中的位置,而不是整个makefile展开后的最终值。
<pre name="code" class="html">       x := foo
       y := $(x) bar
       x := xyz

      在上例中,y的值将会是 foo bar ,而不是 xyz bar 了


******转载自 http://www.cnblogs.com/wanqieddy/archive/2011/09/21/2184257.html ******

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值