What's the difference between := and = in Makefile?

前端 未结 4 1546
既然无缘
既然无缘 2021-01-30 02:23

For variable assignment in Make, I see := and = operator. What\'s the difference between them?

相关标签:
4条回答
  • 2021-01-30 02:40

    For me, the best way to see it in practice is during this Makefile snippet:

    Simple assignment

    XX := $(shell date) // date will be executed once
    tt:
        @echo $(XX)
        $(shell sleep 2)
        @echo $(XX)
    
    

    Running

    make tt
    

    Will produce:

    sex 22 jan 2021 14:56:08 -03
    sex 22 jan 2021 14:56:08 -03
    

    ( Same value )

    Expanded assignment

    XX = $(shell date) // date will be executed every time you use XX
    tt:
        @echo $(XX)
        $(shell sleep 2)
        @echo $(XX)
    
    

    Running

    make tt
    

    Will produce:

    sex 22 jan 2021 14:56:08 -03
    sex 22 jan 2021 14:58:08 -03
    

    Different values

    0 讨论(0)
  • 2021-01-30 02:41

    From http://www.gnu.org/software/make/manual/make.html#Flavors:

    = defines a recursively-expanded variable. := defines a simply-expanded variable.

    0 讨论(0)
  • 2021-01-30 02:48

    Simple assignment :=

    A simple assignment expression is evaluated only once, at the very first occurrence. For example, if CC :=${GCC} ${FLAGS} during the first encounter is evaluated to gcc -W then each time ${CC} occurs it will be replaced with gcc -W.

    Recursive assignment =

    A Recursive assignment expression is evaluated everytime the variable is encountered in the code. For example, a statement like CC = ${GCC} {FLAGS} will be evaluated only when an action like ${CC} file.c is executed. However, if the variable GCC is reassigned i.e GCC=c++ then the ${CC} will be converted to c++ -W after the reassignment.

    Conditional assignment ?=

    Conditional assignment assigns a value to a variable only if it does not have a value

    Appending +=

    Assume that CC = gcc then the appending operator is used like CC += -w
    then CC now has the value gcc -W

    For more check out these tutorials

    0 讨论(0)
  • 2021-01-30 02:50

    This is described in the GNU Make documentation, in the section titled 6.2 The Two Flavors of Variables .

    In short, variables defined with := are expanded once, but variables defined with = are expanded whenever they are used.

    0 讨论(0)
提交回复
热议问题