linux c 关于进程等待的代码

本文讲解"linux c 关于进程等待的代码",用于解决相关问题。

下面资料是关于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中。

关于 "linux c 关于进程等待的代码" 就介绍到此。希望多多支持编程宝库

记录一次采坑--如何处理Linux动态库同名函数?:本文讲解"记录一次采坑--怎么处理Linux动态库同名函数?",用于解决相关问题。一、背景介绍需求描述:业务提供一个鉴权的静态库,我只需要从url 和 参数中提取相应的参数传给业务的静态库 ...