似乎bash
并且zsh
将在子进程中执行变量和算术扩展
a) 他们遵循重定向运算符,如<
,或.>
>>
<<<
b)他们所属的命令不是内置或函数。
bash -c 'i=0; /bin/echo > $((i=7)).txt; echo $i'
0
zsh -c 'i=0; /bin/echo > $((i=7)).txt; echo $i'
0
ksh -c 'i=0; /bin/echo > $((i=7)).txt; echo $i'
7
ksh
上面就像除bash
or之外的任何其他 shell zsh
。
这与算术扩展无关:类似地,同样的事情发生在
unset i; /bin/echo >${i:=7}.txt; echo $i
只会在or7
以外的 shell 中打印。bash
zsh
然而,好像这还不够糟糕,行为在bash
和之间以任何可理解的方式不一致zsh
:
bash -c 'i=0; command echo > $((i++)).txt; echo $i'
1
zsh -c 'i=0; command echo > $((i++)).txt; echo $i'
0
bash -c 'i=0; i=$i /usr/bin/printenv i > $((++i)).bash; echo $i; cat *.bash'
0
0
zsh -c 'i=0; i=$i /usr/bin/printenv i > $((++i)).zsh; echo $i; cat *.zsh'
0
1
所以,我的问题是:标准是怎么说的?这可以接受吗?
我能够找到很多关于变量赋值的信息,比如KEY=val cmd
它们可能会或可能不会“影响当前的执行环境”,但没有关于重定向、$
扩展和外部命令之间的交互。
并且它不可能也适用于作为$
-expansions 的一部分完成的变量分配,因为无论是外部命令还是内置命令,都会ls $((i=2+3))
导致在所有 shelli
中设置为。5
ls