Chinaunix首页 | 论坛 | 博客
  • 博客访问: 393003
  • 博文数量: 119
  • 博客积分: 1796
  • 博客等级: 上尉
  • 技术积分: 890
  • 用 户 组: 普通用户
  • 注册时间: 2010-05-14 10:16
个人简介

守正

文章分类
文章存档

2013年(1)

2011年(40)

2010年(78)

分类: LINUX

2010-06-09 10:33:48

一、变量引用
   Makefile中,变量也叫宏。
   对变量的引用,只须在变量名前加上$。
   名字长度超过一个字符的变量,在引用时必须加上小括号。例如:$(h) $h 实际完全相同,都代表对变量z的引用,而对变量 hao 的引用,则必须采用格式 $(hao) 。

二、Makefile中变量赋值的几种方式
   转自:http://dev.csdn.net/htmls/79/79172.html

    在Makefile中,对变量的赋值,有好几种 方式,它们的意义、使用的场合都各不相同,初学者往往比较迷惑。这里对它们的用法简要介绍一下。

1、= 递归展开赋值
    这是默认的赋值方式。Makefile是两遍解析的,若一个变量引用另外一个变量,两个变量定义的位置,谁在前谁在后没有任何关系,都能达到同样的效果。如:
SUBARCH=arm
ARCH = $(SUBARCH)
all:
    @echo $(ARCH)

输出:
arm


ARCH = $(SUBARCH)
SUBARCH=arm
all:
    @echo $(ARCH)

也输出:
arm


2、:= 直接赋值
   不会递归展开,若引用的变量不存在,就展开为空串。如:
SUBARCH=arm
ARCH = $(SUBARCH)
all:
    @echo $(ARCH)
输出:
arm


ARCH = $(SUBARCH)
SUBARCH=arm
all:
    @echo $(ARCH)
输出:
(空串)

3、?= 如果没有初始化该变量,就给它赋上默认值。如:
ARCH=arm
ARCH ?= i386
all:
    @echo $(ARCH)

输出:
arm


ARCH ?= i386
all:
    @echo $(ARCH)

输出:
i386
 


4、+= 给该变量追加值,例如:
ARCH=arm-
ARCH+=v6
all:
    @echo $(ARCH)
输出:
   arm-v6
阅读(674) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~