Makefile中$$的使用


在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
       echo $$var             # e
此时,b、d、e行的输出结果分别为3、3、4,符合用户的预期。

另外,在Makefile中,$$还被用来做二次扩展,即SECONDEXPANSION。
使用时,必须在最前面加上一行:
.SECONDEXPANSION    # 使用二次扩展必须添加此行
关于二次扩展,看了好几个博客,还是未能深刻理解,有待后续研究。
请各位看官,不吝赐教。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM