在Makefile中,对变量的赋值,有好几种方式,它们的意义、使用的场合都各不相同,初学者往往比较迷惑。这里对它们的用法简要介绍一下。
= 递归展开赋值,这是默认的赋值方式。Makefile是两遍解析的,若一个变量引用另外一个变量,两个变量定义的位置,谁在前谁在后没有任何关系,都能达到同样的效果。如:
SUBARCH=arm
ARCH =
$(SUBARCH)
all:
@echo $(ARCH)
输出:
arm
而
ARCH =
$(SUBARCH)
SUBARCH=arm
all:
@echo $(ARCH)
也输出:
arm
?=: 如果没有初始化该变量,就给它赋上默认值。如:
ARCH=arm
ARCH ?= i386
all:
@echo $(ARCH)
输出:
arm
而
ARCH ?= i386
all:
@echo $(ARCH)
输出:
i386
:= 直接赋值,不会递归展开,若引用的变量不存在,就展开为空串。如:
SUBARCH=arm
ARCH =
$(SUBARCH)
all:
@echo $(ARCH)
输出:
arm
而
ARCH =
$(SUBARCH)
SUBARCH=arm
all:
@echo $(ARCH)
输出:
(空串)