码迷,mamicode.com
首页 > 其他好文 > 详细

makefile之变量赋值

时间:2016-06-04 00:33:09      阅读:282      评论:0      收藏:0      [点我收藏+]

标签:

makefile中变量赋值有4种方法:

          = ,   := ,  += ,  ?=

   :直接赋值

      变量 = 值

  :=   :位置相关赋值

      如果右值为一个值,那么它和=没区别,如果右值为变量,那么左边变量的值等于右边变量当前位置的值,什么意思呢?

a = abc
b = $(a)
a = jkl

all:
	@echo $(b)
	
.PHONY:all

 执行这个makefile,输出 b的值为jkl,  在 b = $(a) 这句中,变量a的值被延迟展开,即由变量a最后一条赋值语句 a = jkl 决定。如果b赋值时采用 :=,则情况就不同了:

a = abc
b := $(a)
a = jkl

all:
	@echo $(b)
	
.PHONY:all

 此时输出b的值为abc, 它的意思就是获得当前位置变量 a的值赋值给b。

 

  ?=  :询问左边变量是否定义过,即是否使用过赋值操作,没有则赋值,否则忽略。注意是是否定义过,而不是是否为空值,并且还要注意空值不等于空格,tab键等。

      这里扯到赋空格,怎么符空格?或者tab

spacevalue=空格/tab#

      需要注意的是#注释符是必须的,此时spacevalue的值就是赋值符=后面开始至#前这段,关于注释符有个陷阱, 假设定义一个变量dir,给它赋值一个路径

dir =/home/thomas  #xx的路径

     这是由于变量赋值时,赋值号左右两边的空格,tab都将忽略,是从第一个非空格,非tab到最后一个非空格,非tab结束,除非遇到注释符,否则到注释符才算结束。

 

  +=  :追加赋值

  

  一个变量最终的值由上述赋值操作按照规则逐一计算决定

  

makefile之变量赋值

标签:

原文地址:http://www.cnblogs.com/thammer/p/5554859.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!