Makefile和使用$$

所以我有一个Makefile文件,其中包含我试图理解的代码:

for file_exe in `find . -name "zip_exe-*"`; do \ ./$${file_exe} -d $(UNZIP_PATH)/lib; \ done 

据我所知,这段代码将尝试find一些可执行的zip文件,并将这些zip文件解压缩到一个位置。 但是让我困惑的是$${file_exe}是如何工作的。 为什么需要双$$ ? 我想这与某些bash命令是从一个makefile运行的事实有关,但是我不能自己解释为什么需要$$ ,而一个简单的$不起作用,因为这个命令正在运行一个子shell无论如何。

需要区分是否需要使用$作为引入make-variable引用,如${FOOBAR}或作为传递到shell的纯$。 make规范 (Section Macros)说要做后者,你必须使用$$来代替$并传递给shell。 实际上,您的代码片段的内容如下所示

 for file_exe in `find . -name "zip_exe-*"`; do \ ./${file_exe} -d some/unzip/path/lib; \ done 

到壳。

样式注释:迭代由反引号创建的文件列表被认为是不好的样式,因为它可能溢出ARG_MAX限制。 最好一个接一个地读取文件名

 find . -name "zip_exe-*" | \ while read -r file_exe; do \ ./${file_exe} -d some/unzip/path/lib; \ done