当一个程序创建的子进程比父进程提前结束,内核仍然保存一些它的信息以便父进程会需要它 - 比如,父进程可能需要检查子进程的退出状态。为了得到这些信息,父进程调用‘wait()’;当这个调用发生,内核可以丢弃这些信息。
在子进程终止后到父进程调用‘wait()’前的时间里,子进程被称为‘僵死进程’(‘zombie’)。(如果你用‘ps’,这个子进程会有一个‘Z’出现在它的状态区里指出这点。)即使它没有在执行,它仍然占据进程表里一个位置。(它不消耗其它资源,但是有些工具程序会显示错误的数字,比如中央处理器的使用;这是因为为节约空间进程表的某些部份与会计数据(accounting info)是共用(overlaid)的。)
这并不好,因为进程表对于进程数有固定的上限,系统会用光它们。即使系统没有用光 ,每一个用户可以同时执行的进程数有限制,它总是小于系统的限制。顺便说一下,这也正是你需要总是 检查‘fork()’是否失败的一个原因。
如果父进程未调用wait函数而终止,子进程将被‘init’进程收管,它将控制子进程退出后必须的清除工作。(‘init’是一个特殊的系统程序,进程号为1 - 它实际上是系统启动后运行的第一个程序),
阅读(1710) | 评论(0) | 转发(0) |