一、变量引用 Makefile中,变量也叫宏。
对变量的引用,只须在变量名前加上$。
名字长度超过一个字符的变量,在引用时必须加上小括号。例如:$(h) $h 实际完全相同,都代表对变量z的引用,而对变量 hao 的引用,则必须采用格式 $(hao) 。
二、Makefile中变量赋值的几种方式 转自:http://dev.csdn.net/htmls/79/79172.html
在Makefile中,对变量的赋值,有好几种
方式,它们的意义、使用的场合都各不相同,初学者往往比较迷惑。这里对它们的用法简要介绍一下。
1、= 递归展开赋值 这是默认的赋值方式。Makefile是两遍解析的,若一个变量引用另外一个变量,两个变量定义的位置,谁在前谁在后没有任何关系,都能达到同样的效果。如:
SUBARCH=armARCH = $(SUBARCH)all:
@echo $(ARCH)
输出:
arm
而
ARCH = $(SUBARCH)SUBARCH=armall:
@echo $(ARCH)
也输出:
arm
2、:= 直接赋值
不会递归展开,若引用的变量不存在,就展开为空串。如:
SUBARCH=arm
ARCH = $(SUBARCH)
all:
@echo $(ARCH)
输出:
arm
而
ARCH = $(SUBARCH)
SUBARCH=arm
all:
@echo $(ARCH)
输出:
(空串)
3、?= 如果没有初始化该变量,就给它赋上默认值。如:
ARCH=armARCH ?= i386
all:
@echo $(ARCH)
输出:
arm而
ARCH ?= i386
all:
@echo $(ARCH)
输出:
i386 4、+= 给该变量追加值,例如:
ARCH=arm-
ARCH+=v6
all:
@echo $(ARCH)
输出:
arm-v6
阅读(674) | 评论(0) | 转发(0) |