考虑一下下面的例子,似乎它在索引0中运行得很好:
$ a1=(1 2 3)
$ a2=(a b c)
$ for x in a1 a2; do echo "${!x}"; done
1
a
$ for x in a1 a2; do echo "${!x[0]}"; done
1
a但是,对于索引1,它不会输出任何内容:
$ for x in a1 a2; do echo "${!x[1]}"; done 数组本身是可以的:
$ echo "${a1[1]} ${a2[1]}"
2 b的真实生活用例
SHIBB=(https://shibboleth.net/downloads/service-provider/3.0.2/ shibboleth-sp-3.0.2 .tar.gz)
XERCES=(http://apache.mirrors.nublue.co.uk//xerces/c/3/sources/ xerces-c-3.2.1 .tar.gz)
XMLSEC=(http://apache.mirror.anlx.net/santuario/c-library/ xml-security-c-2.0.1 .tar.gz)
XMLTOOL=(http://shibboleth.net/downloads/c++-opensaml/latest/ xmltooling-3.0.2 .tar.gz)
OPENSAML=(http://shibboleth.net/downloads/c++-opensaml/latest/ opensaml-3.0.0 .tar.gz)
typeset -n x
for x in XERCES XMLSEC XMLTOOL OPENSAML SHIBB; do
url="${x[0]}" app="${x[1]}" ext="${x[2]}"
[ -f "./${app}${ext}" ] || wget "${url}${app}${ext}"
tar -xf "./${app}${ext}"
cd "./${app}" && ./configure && make -j2 && make install && ldconfig
cd ..
done发布于 2018-09-04 20:54:12
"${!x[1]}"是一个间接引用,它使用数组x的索引D2中的元素。
$ foo=123; bar=456; x=(foo bar); echo "${!x[1]}"
456在当前版本的Bash (4.3及以上版本)中,您可以使用名称厨师获得所需的内容:
$ a=(00 11 22 33 44)
$ typeset -n y=a
$ echo "${y[3]}"
33也就是说,在设置了nameref之后,"${y[3]}"是对由y命名的数组中的元素3的引用。
要像在问题中那样循环数组,只需使x成为一个名称。
a1=(1 2 3); a2=(a b c)
typeset -n x;
for x in a1 a2; do
echo "${x[1]}"
donefor循环完成的赋值改变了x本身的值(更改了引用指向的值)。常规赋值(x=123,或x[1]=123)更改当前由x引用的变量。因此,这将将a1[1]和a2[1]更改为foo:
typeset -n x;
for x in a1 a2; do
x[1]=foo
done"${!x[0]}"看起来起作用的原因是x和x[0]是等价的。如果在循环中有echo "${x[0]}" (没有砰),就会得到a1,a2,和echo "$x"一样。
https://unix.stackexchange.com/questions/466859
复制相似问题