下面资料是关于linux c 关于进程等待的内容,希望能对码农有较大好处。
#include <sys/types.h>
#include <stdio.h>
#include <sys/wait.h>
void check_exit(int status);
main()
{
pid_t pid;
int status;
if((pid = fork()) < 0)
{
printf("fork error!!n");
exit(0);
}
else if(pid == 0)
{
printf("child process exitn");
exit(0);
}
else
{
if(wait(&status) != pid)
{
printf("wait error!!");
exit(0);
}
check_exit(status);
}
}
void check_exit(int status)
{
if(WIFEXITED(status))
printf("eixtn");
else if(WIFSIGNALED(status))
printf("killed by signaln");
else if(WIFSTOPPED(status))
printf("stopped by signaln");
else if(WIFCONTINUED(status))
printf("continued");
}
等待进程改变其状态。所有下面哪些调用都被用于等待子进程状态的改变,获取状态已改变的子进程信息。状态改变可被认为是:1.子进程已终止。2.信号导致子进程停止执行。3.信号恢复子进程的执行。在子进程终止的情况下,wait调用将允许系统释放与子进程关联的资源。如果不执行wait,终止了的子进程会停留在"zombie"状态。如果发现子进程改变了状态,这些调用会立即返回。反之,调用会被阻塞直到子进程状态改变,或者由信号处理句柄所中断(假如系统调用没有通过sigaction的SA_RESTART标志重启动)。wait系统调用挂起当前执行中的进程,直到它的一个子进程终止。waitpid挂起当前进程的执行,直到指定的子进程状态发生变化。默认,waitpid只等待终止状态的子进程,但这种行为可通过选项来改变。waitid系统调用对于等待哪个子进程状态改变提供了更精确的控制。子进程已终止,父进程尚未对其执行wait操作,子进程会转入“僵死”状态。内核为“僵死”状态的进程保留最少的信息量(进程标识,终止状态,资源使用信息),过后父进程执行wait时可以获取子进程信息。只要僵死的进程不通过wait从系统中移去,它将会占据内核进程表中的一个栏位。如果进程表被填满,内核将不能再产生新进程。如果父进程已终止,它的僵死子进程将由init进程收养,并自动执行wait将它们移去。wait(等待子进程中断或结束)
#include<sys/types.h>
#include<sys/wait.h>
函数说明wait()会暂时停止目前进程的执行(挂起父进程),直到有信号来到或子进程结束。如果在调用wait()时子进程已经结束,则wait()会立即返回子进程结束状态值。子进程的结束状态值会由参数status返回,而子进程的进程识别码也会一快返回。如果不在意结束状态值,则参数status可以设成NULL。如果调用wait的进程没有子进程则会调用失败,子进程的结束状态值请参考waitpid()如果执行成功则返回子进程识别码(PID),如果有错误发生则返回-1。失败原因存于errno中。