更多的是一个概念性问题。如果我写一个 bash 脚本来做类似的事情
control_c()
{
echo goodbye
exit #$
}
trap control_c SIGINT
while true
do
sleep 10 #user wants to kill process here.
done
sleep 10 运行时 control+c 不会退出。是因为linux sleep忽略SIGINT吗?有没有办法绕过这个问题,让用户能够通过 cntrl+c 退出睡眠状态?
您所描述的内容与仅发送给您的中断信号一致bash
脚本,而不是进程组。您的脚本收到信号,但是sleep
不,所以你的陷阱直到之后才能执行sleep
完成。标准技巧是跑sleep
在背景和wait
上,这样wait
接收中断信号。然后您还应该明确发送SIGINT
任何仍在运行的子进程,以确保它们退出。
control_c()
{
echo goodbye
kill -SIGINT $(jobs -p)
exit #$
}
trap control_c SIGINT
while true
do
sleep 10 &
wait
done
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)