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