makefile中一些操作符 =+=:= ?=的含义

it2022-05-05  151

1、“=”的作用 举例理解最快:

x =foo y = $(x) bar x = xyz all: echo $(y)

输出: xyz bar 原因是为什么呢?为什么不是foo bar呢? 解释: 当执行make命令后makefile中变量展开; 原本应该如此 x=foo; y=foo bar; x =xyz 但实际是展开时x为 xyz, "="寻找的是变量最终的值; y=$(x) bar 就变成了 xyz bar x最终为 xyz

举例二:

x :=foo y := $(x) bar x := xyz all: echo $(y)

*输出:*foo bar 这又是什么原因呢??“=” 换成了 “:=”结果差很大; 解释: :=的作用域取决于 当前变量解析时所处的位置替换,并不去最终的值; 因此当解析到y :=$(x) bar时,x的值为foo 替换后就是 foo bar

举例三:

x ?=foo y := $(x) bar x ?= xyz all: echo $(x) echo $(y)

输出 : foo foo bar 首先有输出为 foo 证明执行 x?=foo y 的值为 foo bar 证明第二句 也执行了; 那x ?= xyz 没执行吗 解释:是 这样的,?=是做了个判断,如果该变量已经有了值则不对它进行再次 赋值覆盖,如果没有值则进行赋值;

+=就相当于 java中字符串 连接 string A += B A就是 A+B的内容;


最新回复(0)