【shell】我的wait为什么不能用

希望实现这样的一个功能:主脚本会运行几个后台进程,并希望这几个后台进程运行完之后,主进程才会退出。

RT,设想一个文件a,希望a的每一行都表示一个后台进程,有如下内容:

$ cat a
1
2
3
4
5

>> scene 1

脚本test_wait_1这样写:

#!/bin/bash
# filename:test_wait_1

cat a | while read line
do
    echo $line &
done
wait
echo "wait done"

运行结果:

#result
$ bash test_wait_1
1
5
3
wait done
4
2

显然,不尽如人意。

>> scene 2

脚本test_wait_2,做了一下修改:

#!/bin/bash
# filename:test_wait_2

while read line
do
    echo $line &
done < "a"
wait
echo "wait done"

运行结果:

$ bash test_wait_2
1
2
5
4
3
wait done

结果符合预期!!

总结

维基百科中有这样一段话:

其中n是当前正在执行的后台进程的pid,或工作的工作ID。如果没有给定n,命令会等待shell调用的所有工作终止。

wait一般返回最后一个工作的退出状态。如果n所指的工作不存在,或没有工作要等待,它会返回127。

因为wait需要知道当前shell执行环境的工作表,它通常为shell内建命令。

这样看来仿佛test_wait_1中的用法也没有什么问题,但实际上shell的管道|实际上是产生了一级子shell,也就是在test_wait_1中的后台进程echo $line &是主进程子shell的后台进程。而wait只会等待当前进程的后台进程执行完毕,所以test_wait_1在遇到wait语句直接退出了。

test_wait_2中,通过< "a"将a文件的内容标准输入到while中,并未通过管道输入到while中,所以后台进程属于主进程。wait会等待所有的后台进程完成以后退出,

这也就是test_wait_1test_wait_2这2个脚本运行的不同之处。

参考资料:

https://zh.wikipedia.org/wiki/Wait_(%E5%91%BD%E4%BB%A4)

http://blog.csdn.net/shuanghujushi/article/details/38186303

原文地址:https://www.cnblogs.com/wangxin201492/p/5030983.html