makefile中的变量赋值

Posted insistYuan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了makefile中的变量赋值相关的知识,希望对你有一定的参考价值。

  在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

  这样定义是有好处的。

以上是关于makefile中的变量赋值的主要内容,如果未能解决你的问题,请参考以下文章

makefile(02)_变量

makefile变量赋值

Makefile的理论学习记录

Makefile的理论和实践的学习记录

Makefile的理论和实践的学习记录

变量和不同的赋值方式