展开全部
一般杀死父进程也会杀子进程。
杀死父进程后,你看到子进程还活着的原因是因为孩子在选择处理SIGKILL事件后才会死亡。它不必马上处理。你的脚本运行一个sleep()命令,在睡眠完成之前,它不会被唤醒以处理任何事件。
为什么是PPID#1?父进程已经死亡,不再在进程表中。child.sh并不会莫名其妙地连接到init。它根本没有运行的父进程。说它和init相关联是因为会产生一个假象:杀死父进程会使祖父母成为孩子的主人。两者都是不正确的。该子进程仍然存在于进程表中并且正在运行,但是不会处理基于它的进程ID的新事件,直到它处理完SIGKILL。这意味着孩子是一个僵尸前,走路死亡,有被贴上标签的危险。
杀死进程组是不同的,用来杀死兄弟姐妹,并且通过进程组#来杀死父进程。也许同样重要的是要注意,“杀死一个进程”本身并不是以人类的方式“杀戮”,在那里你期望进程被摧毁,所有的记忆都会像以前一样回归。它只是发送一个特定的事件,其中很多,它处理的过程。如果这个过程没有正确处理,那么一段时间以后,操作系统会强行进行“清理”。
它(杀害)不会立即发生,因为孩子(甚至父母)可能已经写了一些东西到磁盘上,等待I / O完成或者做一些可能危及系统稳定性或文件完整性的其他关键任务。
杀死父进程后,你看到子进程还活着的原因是因为孩子在选择处理SIGKILL事件后才会死亡。它不必马上处理。你的脚本运行一个sleep()命令,在睡眠完成之前,它不会被唤醒以处理任何事件。
为什么是PPID#1?父进程已经死亡,不再在进程表中。child.sh并不会莫名其妙地连接到init。它根本没有运行的父进程。说它和init相关联是因为会产生一个假象:杀死父进程会使祖父母成为孩子的主人。两者都是不正确的。该子进程仍然存在于进程表中并且正在运行,但是不会处理基于它的进程ID的新事件,直到它处理完SIGKILL。这意味着孩子是一个僵尸前,走路死亡,有被贴上标签的危险。
杀死进程组是不同的,用来杀死兄弟姐妹,并且通过进程组#来杀死父进程。也许同样重要的是要注意,“杀死一个进程”本身并不是以人类的方式“杀戮”,在那里你期望进程被摧毁,所有的记忆都会像以前一样回归。它只是发送一个特定的事件,其中很多,它处理的过程。如果这个过程没有正确处理,那么一段时间以后,操作系统会强行进行“清理”。
它(杀害)不会立即发生,因为孩子(甚至父母)可能已经写了一些东西到磁盘上,等待I / O完成或者做一些可能危及系统稳定性或文件完整性的其他关键任务。
展开全部
被杀掉属于异常退出并没有去结束子进程,所以子进程还在。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在,父进程变成init,父进程号为1
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
存在. 子进程变成孤儿进程, init接收管理; 如果centos7是systemd接收管理;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
父进程死掉 子进程就没有了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |