本节可以学到:
- wait与waitpid()的使用
更新记录
- 2017/10/18:写完初稿
waitpid()函数:中断(结束)进程函数
使用场景
希望知道某一个自己创建的子进程何时结束,从而方便父进程做一些处理动作。
头文件与函数原型
- 头文件:
#include <sys/types.h>
#include <sys/wait.h>
- 定义函数:
pid_t waitpid(pid_t pid, int * status, int options);
函数说明
- 如果子进程还没有停止运行或结束,则调用waitpid()函数的父进程则会被
阻塞
,暂停运行.直到有信号来
到或子进程结束
. - 如果在调用wait()时子进程已经结束, 则wait()会立即返回子进程
结束状态值
. - 如果没有子进程, 就返回错误
参数
- 子进程的
结束状态值
会由参数status
返回, 而子进程的进程识别码
也会一起返回. 如果不在意结束状态值, 则参数status 可以设成NULL. 参数pid 为欲等待的
子进程识别码
, 其他数值意义如下:
1、pid<-1 等待进程组识别码
为pid绝对值
的任何子进程.
2、pid=-1 等待任何子进程, 相当于wait().
3、pid=0 等待进程组识别码
与目前进程相同的任何子进程.
4、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 中.
wait函数
头文件与函数原型
- 头文件:
#include <sys/types.h>
#include <sys/wait.h>
- 定义函数:
pid_t wait (int * status);
函数说明
作用: 相当于pid=-1的waitpid()
范例
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>
main()
{
pid_t pid;
int status, i;
if(fork() == 0)
{
printf("This is the child process. pid =%d\n", getpid());
exit(5);
}
else
{
sleep(1);
printf("This is the parent process, wait for child...\n";
pid = wait(&status);
i = WEXITSTATUS(status);
printf("child's pid =%d . exit status=^d\n", pid, i);
}
}
执行:
This is the child process. pid=1501
This is the parent process, wait for child…
child’s pid =1501, exit status =5
总结
wait()函数涉及主进程与子进程的关系; 大体作用就是主进程阻塞,等子进程结束的信号
waitpid()功能要更丰富, 可以涉及到进程组的等待