6.3.11.17. wait / waitpid

6.3.11.17.1. wait

wait的函数原型为 pid_t wait (int * status); ,相关的头文件是 #include<sys/types.h> / #include<sys/wait.h>

进程调用wait后,就立即阻塞自己,由wait自动分析是否当前进程的某个子进程已经退出,如果找到了这样一个已经变成僵尸的子进程,wait就会收集这个子进程的信息,并把它彻底销毁后返回。如果没有找到这样的子进程,wait就会一直阻塞直到出现一个这样的子进程为止。

子进程的结束状态值会由参数status返回,如果不在意结束状态值,则参数status可以设成NULL。

如果执行成功则返回子进程识别码(PID),如果有错误发生则返回-1。失败原因存于errno中。

6.3.11.17.2. waitpid

waitpid的函数原型为 pid_t waitpid(pid_t pid,int * status,int options); ,相关的头文件是 #include<sys/types.h> / #include<sys/wait.h>

waitpid会暂时停止目前进程的执行,直到有信号来到或子进程结束。如果在调用waitpid时子进程已经结束,则waitpid会立即返回子进程结束状态值。子进程的结束状态值会由参数status返回,如果不在意结束状态值,则参数status可以设成NULL。

参数pid 为欲等待的子进程识别码,其他数值意义如下:

  • pid < -1
    • 等待进程组识别码为pid绝对值的任何子进程

  • pid = -1
    • 等待任何子进程,相当于wait

  • pid = 0
    • 等待进程组识别码与目前进程相同的任何子进程

  • pid > 0
    • 等待任何子进程识别码为pid的子进程

参数option可以为0或下面的OR组合:

  • WNOHANG
    • 如果没有任何已经结束的子进程则马上返回,不予以等待。

  • WUNTRACED
    • 如果子进程进入暂停执行情况则马上返回,但结束状态不予以理会

子进程的结束状态返回后存于status,可用下面几个宏判别结束情况:

  • WIFEXITED(status)
    • 如果子进程正常结束则为非0值

  • WEXITSTATUS(status)
    • 取得子进程exit()返回的结束代码,一般会先用WIFEXITED来判断是否正常结束才能使用此宏

  • WIFSIGNALED(status)
    • 如果子进程是因为信号而结束则此宏值为真

  • WTERMSIG(status)
    • 取得子进程因信号而中止的信号代码,一般会先用WIFSIGNALED来判断后才使用此宏

  • WIFSTOPPED(status)
    • 如果子进程处于暂停执行情况则此宏值为真。一般只有使用WUNTRACED时才会有此情况

  • WSTOPSIG(status)
    • 取得引发子进程暂停的信号代码,一般会先用WIFSTOPPED来判断后才使用此宏

如果执行成功则返回子进程识别码(PID),如果有错误发生则返回-1。失败原因存于errno中。