我试图理解“while read”是如何在bash中运行的,我遇到了一个我无法解释的行为:
root@antec:/# var=old_value
root@antec:/# echo "new_value" | read var && echo $var
old_value
root@antec:/#
“正在读取”时效果很好:
root@antec:/# var=old_value
root@antec:/# echo "new_value" | while read var; do echo $var; done
new_value
root@antec:/#
有人可以解释为什么在没有使用读取时它不起作用?此外,我不明白如何在管道之后从所谓的子壳中看到主壳中“var”的值。
谢谢
答案 0 :(得分:6)
我认为这是优先问题,有|优先级高于&&。首先分组为:
(echo "new_value" | read var) && echo $var
第二个分组为:
echo "new_value" | (while read var; do echo $var; done)
答案 1 :(得分:6)
为什么你认为它适用于第二种情况?它并没有真正更新var
。在使用echo $var
的行后while
进行查看。
解释:在|
之后执行的任何内容都在具有自己的var
副本的子shell中执行。在任何一种情况下,原始var
都不会受到影响。回显的内容取决于echo
是否在read
的同一子shell中被调用。
答案 2 :(得分:2)
我不想立即打印变量,但稍后再使用它,这有效:
var=old_value
read var < <(echo "new_value")
echo $var
> new_value
或者:
var=old_value
tmp=$(echo "new_value")
read var <<<"$tmp"
echo $var
> new_value
答案 3 :(得分:1)
您不需要while
循环:
echo "new_value" | (read var; echo $var)