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