码迷,mamicode.com
首页 > 其他好文 > 详细

Makefile中变量的展开

时间:2019-10-06 18:49:13      阅读:222      评论:0      收藏:0      [点我收藏+]

标签:不同   def   elf   stop   两种   $@   code   解决   event   

在GNU make中对变量的赋值有两种方式:延时变量、立即变量。区别在于它们的定义方式和扩展时的方式不同,前者在这个变量使用时才扩展开,意即当真正使用时这个变量的值才确定;后者在定义时它的值就已经确定了。使用`=’,`?=’定义或使用define指令定义的变量是延时变量;使用`:=’定义的变量是立即变量。需要注意的一点是,`?=’仅仅在变量还没有定义的情况下有效,即`?=’被用来定义第一次出现的延时变量。

对于附加操作符`+=’,右边变量如果在前面使用(:=)定义为立即变量则它也是立即变量,否则均为延时变量。

 

例1.

//Makefile
.PHONY: all

Inst := .$@.d
Defer = .$@.d

all:
        @echo "Inst is $(Inst)"
        @echo "Defer is $(Defer)"


//$ make
Inst is ..d
Defer is .all.d

 

例2.

//Makefile
.PHONY: all

x = foo
y = $(x) b
x = later

xx := foo
yy := $(xx) b
xx := later
all:
        @echo "y is $(y)"
        @echo "yy is $(yy)"

//$ make
y is later b
yy is foo b

 例3.

对延迟变量在赋值导致错误。

//Makefile
.PHONY: all

CFLAGS = -d mm
CFLAGS += -t0x20000
CFLAGS = $(CFLAGS) -O

all:
        @echo "CFLAGS is $(CFLAGS)"

//$ make
Makefile:5: *** Recursive variable CFLAGS references itself (eventually).  Stop.

 

例4.

对于同一变量采用不同的赋值解决例3中的错误

//Makefile
.PHONY: all

CFLAGS = -d mm
CFLAGS += -t0x20000
CFLAGS := $(CFLAGS) -O

all:
        @echo "CFLAGS is $(CFLAGS)"

//$ make
CFLAGS is -d mm -t0x20000 -O

 

Makefile中变量的展开

标签:不同   def   elf   stop   两种   $@   code   解决   event   

原文地址:https://www.cnblogs.com/yangjiguang/p/11627760.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!