关于makefile中变量的多次赋值以及override指令

1 基本原则如下

1.1 原则1

变量的普通赋值是有先后顺序的,后面的赋值会覆盖掉前面的赋值。

1.2 原则2

使用的时候,用的是其前面最后的赋值,就算其后面有使用了override指令的赋值也不会影响这条原则。

1.3 原则3

当使用了override指令定义赋值了变量后,其后对该变量的所有的赋值都是无效的。但是override之前的所有的赋值都是有效的。使用的时候是往前最近原则。

2 override变量、命令行参数和普通变量之间的屏蔽关系

override变量会屏蔽命令行参数,除非用+=;

override变量会屏蔽其后面出现的所有的普通变量的赋值,但是不会屏蔽其前面出现的普通变量的赋值;

命令行参数会屏蔽掉所有的普通变量,只要命令行参数中赋值了,make会忽略掉Makefile中对该变量的赋值。

时间: 2024-12-12 13:52:30

关于makefile中变量的多次赋值以及override指令的相关文章

Makefile中变量赋值的方式

Makefile中的"="":="."?="和"+="区别是:"="是直接给变量赋值.":="是将":="右边中包含的变量直接展开给左边的变量赋值."?="是在该变量没有被赋值 的情况下为其赋值."+="是给该变量追加值.例:a = 1b = 2c := $(a) 3d = 4d ?= 5b += 6结果:a=1c=1 3d=4

ECMAScript中变量的解构赋值

ES6 允许从数组和对象中提取值,对变量进行赋值. 解构赋值的基本用法: 1.数组的解构赋值 let [a, b, c]= [1,2, 3]; console.log(a);//1 console.log(b);//2 console.log(c);//3 2.对象的解构赋值 let { foo:foo2, bar:bar2 } = {foo: "aaa",bar: "bbb" }; console.log(foo2);// "aaa" cons

makefile之变量赋值

makefile中变量赋值有4种方法: = ,   := ,  += ,  ?= = :直接赋值 变量 = 值 :=   :位置相关赋值 如果右值为一个值,那么它和=没区别,如果右值为变量,那么左边变量的值等于右边变量当前位置的值,什么意思呢? a = abc b = $(a) a = jkl all: @echo $(b) .PHONY:all 执行这个makefile,输出 b的值为jkl,  在 b = $(a) 这句中,变量a的值被延迟展开,即由变量a最后一条赋值语句 a = jkl 决

变量和不同的赋值方式(四)

在 makefile 中是支持程序设计语言中变量的概念的,makefile 中的变量只代表文本数据(字符串).那么在 makefile 中的变量名的规则又有哪些呢?a> 变量名可以包含字符.数字以及下划线:b> 不能包含 ":" , "#" , "=" 或 " ":c> 变量名大小写敏感.下来我们来看看变量的定义和使用,如下 下来我们以代码为例来进行分析说明 CC := gcc TARGET := hello

[转] Makefile中调用Shell

1.在Makefile中只能在target中调用Shell脚本,其他地方是不能输出的.比如如下代码就是没有任何输出: VAR="Hello" echo "$(VAR)" all: ..... 以上代码任何时候都不会输出,没有在target内,如果上述代码改为如下: VAR="Hello" all: echo "$(VAR)" ..... 以上代码,在make all的时候将会执行echo命令. 最后打印结果是: echo &q

makefile中的shell编程注意点

参考:http://blog.csdn.net/wanglang3081/article/details/49423105 (1)Makefile本质上来讲也是shell脚本,即每条command都是shell进程,运行完shell进程都会退出.   (2)shell代码行,如果有=的话,=两边不能有空格   (3)Makefile中的shell,每一行是一个进程,不同行之间变量值不能传递.所以,Makefile中的shell不管多长也要写在一行.可以用\来分行写,格式更清晰一点. SUBDIR

erlang中变量作用域

http://erlangdisplay.iteye.com/blog/315452 erlang中变量只能一次赋值,这么“苛刻“的要求下,更别想拥有全局变量了. 变量只在function中存在,这就是函数编程语言的特色. 对于函数参数对应的变量从执行函数开始,到函数执行结束(从咱们编程者的角度来看的确如此,至于从运行时,GC的角度看,咱们就不深究了). 比如下面的函数: Erlang代码   test1(V) -> io:format("V is:~p~n", [V]), % 

整理下makefile中的语法,变量

最近研读了下u-boot的makefile,其中有不少的语法,变量不甚了解,特此将查找到资料记录! 1. if函数很像GNU的make所支持的条件语句--ifeq(参见前面所述的章节),if函数的语法是: $(if <condition>,<then-part>) 或是 $(if <condition>,<then-part>,<else-part>) 可见,if函数可以包含"else"部分,或是不含.即if函数的参数可以是两

makefile的中变量

1.定义命令包 如果Makefile中出现一些相同命令序列,可以为这些相同的命令序列定义一个变量.定义这种命令序列的语法以"define"开始,以"endef"结束,如: define run-yacc yacc $(firstword $^) mv y.tab.c [email protected] endef 这里,"run-yacc"是这个命令包的名字,其不要和Makefile中的变量重名.在"define"和"