书上看到的例子如下:
CC := gcc
HEAD := getarg.h writeinfo.h
SRC := getarg.c writeinfo.c main.c
OBJS := getarg.o writeinfo.o main.o
TT := test
INC = .
CFLAGS = -pipe -g -Wall -I$(INC)
LDFLAGS = -g -Wall
请问Makefile中 := 和 = 的区别?我试过将=和:=互换,结果是一样的。
请问Makefile中 := 和 = 的区别?
版面规则
我们都知道新人的确很菜,也喜欢抱怨,并且带有浓厚的Windows习惯,但既然在这里询问,我们就应该有责任帮助他们解决问题,而不是直接泼冷水、简单的否定或发表对解决问题没有任何帮助的帖子。乐于分享,以人为本,这正是Ubuntu的精神所在。
我们都知道新人的确很菜,也喜欢抱怨,并且带有浓厚的Windows习惯,但既然在这里询问,我们就应该有责任帮助他们解决问题,而不是直接泼冷水、简单的否定或发表对解决问题没有任何帮助的帖子。乐于分享,以人为本,这正是Ubuntu的精神所在。
-
- 帖子: 26
- 注册时间: 2010-04-01 17:23
- clock88731
- 帖子: 206
- 注册时间: 2007-01-01 20:26
- 来自: 湖北武汉
Re: 请问Makefile中 := 和 = 的区别?
我只知道在部分语言中,:=是赋值号,给左边的赋右边的值
=是等号,返回布尔变量
前者相当与C里面的=
后者相当与C里面的==
不知到这里是什么样。
=是等号,返回布尔变量
前者相当与C里面的=
后者相当与C里面的==
不知到这里是什么样。
- gamesun
- 帖子: 119
- 注册时间: 2010-09-06 14:25
Re: 请问Makefile中 := 和 = 的区别?
Makefile里的=显然是赋值的用法clock88731 写了:我只知道在部分语言中,:=是赋值号,给左边的赋右边的值
=是等号,返回布尔变量
前者相当与C里面的=
后者相当与C里面的==
不知到这里是什么样。
风格1: 递归扩展变量
(recursively expanded variable)
变量定义格式是,变量和值之间用等号,即 =
例如:
foo = $(bar)
bar = $(ugh)
ugh = Huh?
all:;echo $(foo)
将显示 Huh?
再例如:
CFLAGS = $(include_dirs) -O
include_dirs = -Ifoo -Ibar
缺点是不能这么定义:CFLAGS = $(CFLAGS) -O ,将会死循环
风格2: 简单扩展变量
(simply expanded variables)
变量定义格式是,变量和值之间用冒号等号,即 :=
例如
x := foo
y := $(x) bar
x := later
等价于:
y := foo bar
x := later
另外 ?= 含义为:没有定义则赋值
FOO ?= bar
等价于
ifeq ($(origin FOO), undefined)
FOO = bar
endif
+= 是为变量后面追加字符
变量替换
$(var:a=b),是将 var 变量中每一个单词后面的 a 替换为 b
$(var:suffix=replacement)
等价于
$(patsubst %suffix,%replacement,$(var))
$(foo:%.o=%.c) ,由于出现了 %, 其功能和 patsubst 等价
$(var:pattern=replacement)
等价于
$(patsubst pattern,replacement,$(var))
- 懒蜗牛Gentoo
- 论坛版主
- 帖子: 7353
- 注册时间: 2007-03-02 17:36
- 系统: Linux Mint
- gamesun
- 帖子: 119
- 注册时间: 2010-09-06 14:25
Re: 请问Makefile中 := 和 = 的区别?
googled
- bzhao
- 帖子: 250
- 注册时间: 2008-07-05 2:15
- 系统: XUbuntu
Re: 请问Makefile中 := 和 = 的区别?
:=
=
区别在于如果等号右边有变量, 前者要立即解析,后者是在使用这个变量的时候解析
=
区别在于如果等号右边有变量, 前者要立即解析,后者是在使用这个变量的时候解析