1. makefile中的环境变量(全局变量)
(1)makefile中使用系统环境变量
makefile中可以直接使用系统中的环境变量(系统环境变量的本质就是全局的键值对)
-
-
如果 makefile 中定义了同名变量,那么环境变量将会被覆盖
-
运行 make 时指定 "-e" 选项,优先使用环境变量
-
1 # 测试makefile中环境变量的使用 2 3 # 例1 4 PATH := my path 5 6 test : 7 @echo "PATH => $(PATH)" 8 9 #输出结果: my path10 11 # 例212 test :13 @echo "PATH => $(PATH)"14 15 # 输出结果 /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games16 17 # 例318 PATH := my path19 20 test :21 @echo "PATH => $(PATH)"22 23 # 执行 make 时添加 -e 选项24 # 输出结果:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games
(2)为什么要在makefile中使用环境变量?
— 优势:环境变量可以在所有 makefile 中使用
— 劣势:过多的依赖于环境变量会导致移植性降低
(3)变量在不同makefile之间的传递方式
— 直接使用系统中的环境变量(不推荐,太依赖于系统)
— 使用 export 定义环境变量进行传递(定义临时的环境变量)
— 定义 make 命令行变量进行传递(推荐)
1 # makefile 演示变量在不同 makefile 之间的传递方式 2 3 # makefile文件 4 5 HOME := my home 6 var := swj 7 8 test : 9 @echo "HOME => $(HOME)"10 @echo "var => $(var)"11 @echo "make another file ..."12 @$(MAKE) -f makefile.1 13 14 # makefile.1文件15 16 test :17 @echo "HOME => $(HOME)"18 @echo "var => $(var)"19 20 # 输出结果:21 HOME => my home22 var => swj23 make another file ...24 make[1]: 正在进入目录 `/home/swj/12-plan/makefile/lesson-7'25 HOME => my home26 var => 27 make[1]:正在离开目录 `/home/swj/12-plan/makefile/lesson-7'
— 该例说明的问题:
-
makefile中定义环境变量会把系统中该环境变量的值覆盖
-
在makefile中定义的变量只具有 "文件作用域" ,在makefile.1 中不能使用
— 遇到的坑:
由于我的ubuntu没有安装Java,没有使用JAVA_HOME这个环境变量,使用的是PATH环境变量,PATH := my path ,导致后面调用make出现错误。原因是由于make是一个进程,它会复制系统的一份环境变量来使用,复制的环境变量作用域是 "进程域", 上面 PATH := my path 就把该环境变量的值更改了,导致后面调用make时出现 "找不到命令" 的错误。环境变量之间的关系如下图所示。
1 # 演示 export 和 命令行传递变量给其它makefile 2 3 # makefile 文件 4 HOME := my home 5 export var := swj 6 new := cool 7 8 test : 9 @echo "HOME => $(HOME)"10 @echo "var => $(var)"11 @echo "make another file ..."12 @$(MAKE) -f makefile.1 13 @$(MAKE) -f makefile.1 new:=$(new)14 15 # makefile1 文件16 test :17 @echo "HOME => $(HOME)"18 @echo "var => $(var)"19 @echo "new => $(new)"20 21 # 输出结果:22 HOME => my home23 var => swj24 make another file ...25 make[1]: 正在进入目录 `/home/swj/12-plan/makefile/lesson-7'26 HOME => my home27 var => swj28 new => 29 make[1]:正在离开目录 `/home/swj/12-plan/makefile/lesson-7'30 make[1]: 正在进入目录 `/home/swj/12-plan/makefile/lesson-7'31 HOME => my home32 var => swj33 new => cool34 make[1]:正在离开目录 `/home/swj/12-plan/makefile/lesson-7'
2. makefile中的局部变量
(1)目标变量
— 作用域只在指定目标及连带规则中
-
-
-
target : name<assignment>value
-
target : override name<assignment>value
-
-
1 # 测试目标变量的使用2 3 var := swj4 test : var := test-var5 6 test :7 @echo "var => $(var)"8 9 # 输出结果:var => test-var
(2)模式变量
— 模式变量是目标变量的扩展
— 作用域只在符合模式的目标及连带规则中
-
-
-
pattern : name <assignment> value
-
pattern : override name <assignment> value
-
-
1 # 测试模式变量的使用 2 3 var := swj 4 %t : var := test-var 5 6 test : 7 @echo "var => $(var)" 8 9 another :10 @echo "var => $(var)"11 12 # 输出结果13 var => test-var14 var => swj
3. makefile中的变量类型
(1)全局变量:makefile 外部定义的环境变量。
(2)文件变量:makefile 中定义的变量。
(3)局部变量:指定目标的变量。