微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

linux – Makefile中的$${HOME}或${HOME}?

$cat Makefile 
all:
    echo VAR is ${HOME}
    echo VAR is $${HOME}

$make
echo VAR is /home/abc
VAR is /home/abc
echo VAR is ${HOME}
VAR is /home/abc

为什么echo VAR在Makefile中是${HOME}语法工作?我想,要使用shell变量你必须使用$${HOME}}

解决方法:

是的,不是.最好使用$$来明确.但是,there is a special rule for environment variables

Variables in make can come from the environment in which make is run. Every environment variable that make sees when it starts up is transformed into a make variable with the same name and value. But an explicit assignment in the makefile, or with a command argument, overrides the environment. (If the `-e’ flag is specified, then values from the environment override assignments in the makefile. See section Summary of Options. But this is not recommended practice.)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐