makefile中 = ,:=,+=有怎么区别?
2个回答
2015-08-05 · 知道合伙人互联网行家
关注
展开全部
= 是最基本的赋值
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值
1、“=”
make会将整个makefile展开后,再决定变量的值。也就是说,变量的值将会是整个makefile中最后被指定的值。看例子:
x = foo
y = $(x) bar
x = xyz
在上例中,y的值将会是 xyz bar ,而不是 foo bar 。
2、“:=”
“:=”表示变量的值决定于它在makefile中的位置,而不是整个makefile展开后的最终值。
x := foo
y := $(x) bar
x := xyz
在上例中,y的值将会是 foo bar ,而不是 xyz bar 了。
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值
1、“=”
make会将整个makefile展开后,再决定变量的值。也就是说,变量的值将会是整个makefile中最后被指定的值。看例子:
x = foo
y = $(x) bar
x = xyz
在上例中,y的值将会是 xyz bar ,而不是 foo bar 。
2、“:=”
“:=”表示变量的值决定于它在makefile中的位置,而不是整个makefile展开后的最终值。
x := foo
y := $(x) bar
x := xyz
在上例中,y的值将会是 foo bar ,而不是 xyz bar 了。
展开全部
+= 是添加(append).
path=a
path+=b
echo $(path) --> a b
=, 和:=的区别在于make什么时候展开后面的变量, VAR=$(variable), =展开$(variable)一次,:=在每次用的时候都会展开。
具体看:
http://www.gnu.org/software/make/manual/make.html
Section 3.7 How make Reads a Makefile
path=a
path+=b
echo $(path) --> a b
=, 和:=的区别在于make什么时候展开后面的变量, VAR=$(variable), =展开$(variable)一次,:=在每次用的时候都会展开。
具体看:
http://www.gnu.org/software/make/manual/make.html
Section 3.7 How make Reads a Makefile
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询