在makefile中赋值方式有:'='、':='、'?='和'+='。
A = a $(B) B = b all: echo $(A) #运行结果:echo a b a b
这种赋值方式是没有先后顺序的,但是这种赋值方式可能会出现问题,例如递归定义时:A = $(A)
A := a $(B) B = b all: echo $(A) # 运行结果:echo a a
这种赋值方式有先后顺序,只能使用已经定义的变量。
A = a A ?= b B ?= c all: echo $(A) $(B) #运行结果:echo a c a c
这种赋值是在询问A是否等于b,如果前边定义了A变量,那么前边定义时A的值是多少还是多少。如果前边没有定义,如B,就对其进行赋值。
A = a A += b all: echo $(A) #运行结果:echo a b a b
这种赋值就是在原有的定义上在添加。
注意:
#定义一个变量其值为空格 nullstring := blank_space := $(nullstring)#end of the line
这样定义是有好处的。