在linux的Makefile中,经常会见到$var和$$var的形式。下面就这两种表示方法的区别进行简单的概述。
在Makefile中的规则命令行中:
$var:将Makefile中的变量var的值,传给shell命令。
$$var:访问shell命令中定义的变量var。
经典示例代码如下所示:
var=3 # a
target:
echo $(var) # b
var=4 # c
echo $(var) # d
echo $$var # e
a:定义Makefile中的变量var,值为3
b:打印Makefile中的变量,值为3
c:定义shell命令中的变量var,值为4,Makefile的变量var不受影响
d:打印Makefile中的变量,值为3
e:打印shell命令中的变量。此时var为未定义的变量。
读者可能会奇怪,shell命令中的var明明已经定义了,为什么是未定义呢?
原因:在Makefile的规则命令,如果相互之间没有使用';\'连接起来的话,相互之间是不能共享变量的。
修改示例代码,使用';\'连接shell规则命令行。
var=3 # a
target:
echo $(var);\ # b
var=4;\ # c
echo $(var);\ # d makefile先要进行扩展,扩展的结果就是echo 3
echo $$var # e makefile将$$VAR先执行一次扩展得到echo $var然后交给shell去解释执行
此时,b、d、e行的输出结果分别为3、3、4,符合用户的预期。
makefile中的makefile变量与shell变量的区别
最新推荐文章于 2023-03-02 12:55:17 发布