首页 > 技术文章 > makefile中的变量赋值

coolYuan 2017-11-17 17:36 原文

  在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

  这样定义是有好处的。

推荐阅读