1. 函数原型:

#include <sys/wait.h>

pid_t wait(int *statloc);

pid_t waitpid(pid_t pid, int *statloc, int options);

ret=成功返回进程ID或者0,失败返回-

(1) statloc是一个整型指针;如果statloc不是一个空指针,则终止进程的终止状态就存放在它指向的单元内;如果不关心终止状态,则可将该参数指定为空指针;

(2) waitpid中的pid参数作用如下:

pid==-1 等待任一子进程。这个waitpid与wait等效; wait(xx) == waitpid(-1, xx, 0);

pid>0 等待进程ID与pid相等的子进程;

pid==0 等待其组ID等于调用进程ID的任一子进程;

pid < -1 等待期组ID等于pid绝对值的任一子进程;

(3) waitpid的options常量:

0-不使用任何选项;

WCONTINUED-若支持作业控制,那么由pid指定的任一子进程在暂停后已经继续,但其状态未被报告,则返回其状态;

WNOHANG-若pid指定的子进程并不是立即可用的,则waitpid不阻塞,此时其返回值为0;

WUNTRACED-若某实现支持作业控制,而由pid指定的任一子进程已处于暂停状态,但是其状态自暂停以后还未报告过,则返回其状态;WIFSTOPPED宏确定返回值是否对应一个暂停子进程;

(4) 检查终止状态的宏:

WIFEXITED(status)-若为正常终止子进程返回的状态,则为真;对于这种情况可执行WEXITSTATUS(status),取子进程传送给exit, _exit, _Exit参数的低八位;

WIFSIGNALED(status)-若为异常终止子进程返回的状态,则为真(接到一个不捕捉的信号)。对于这种情况,可执行WTERMSIG(status),获取子进程终止的信号编号;另外有些实现定义宏WCOREDUMP(status),若以产生终止进程的core文件,则返回真;

WIFSTOPPED(status)-若为当前暂停进程的返回状态,则为真;对于这种情况,可执行WSTOPSIG(status),获取使子进程暂停的信号编号;

WIFCONTINUED(status)-若在作业控制暂停后,已经继续的子进程返回了状态,则为真;(仅用于waitpid)

2. wait与waitpid区别:

(1) 在一个进程终止前,wait使其调用者阻塞,而waitpid有一个选项,可以使调用者不阻塞;

(2) waitpid并不等待其调用后的第一个终止子进程,它有若干个选项,可以控制它所等待的子进程;

waitpid提供了wait函数没有的三个功能:

(1) waitpid可以等待一个特定的进程,而wait则返回任一终止子进程的状态;

(2) waitpid提供了一个wait的非阻塞版本。有时用户希望获取一个子进程的状态,但不想阻塞;

(3) waitpid支持作业控制;

3. SIGCHLD信号处理多个子进程:

正确做法:

 void sig_child(int signo)
{
pid_t pid;
int stat; while ((pid = waitpid(-, &stat, WNOHANG)) > )
printf("child %d terminated\n", pid);
return;
}

在多个子进程可能同时终止的时候,同时产生多个SIGCHLD信号,因为信号不排队,所以信号处理函数可能只被调用一次,从而有多个子进程没有wait成为僵尸进程;

所以我们需要在产生信号的时候,对所有结束的子进程进行回收,于是使用while循环;

wait不能使用在while中,因为wait是阻塞的,比如当某子进程一直不停止,它将一直阻塞,从而影响了父进程;

于是使用waitpid,options设置为WNOHANG,可以在非阻塞情况下处理多个退出子进程;

wait与waitpid的更多相关文章

  1. Linux 等待进程结束 wait() 和 waitpid()

    若子进程先于父进程结束时,父进程调用wait()函数和不调用wait()函数会产生两种不同的结果: --> 如果父进程没有调用wait()和waitpid()函数,子进程就会进入僵死状态. -- ...

  2. linux下使用fork,exec,waitpid模拟system函数

    代码如下: #include <sys/types.h> #include <sys/wait.h> #include <unistd.h> #include &l ...

  3. 详解wait和waitpid函数

    #include <sys/types.h> /* 提供类型pid_t的定义 */ #include <sys/wait.h> pid_t wait(int *status) ...

  4. 父进程等待子进程结束 waitpid wait

    我们一直在强调一个概念就是进程是一个程序执行的实例,是内核在虚拟概念下创建的实体,它实例化的体现在用户态就是程序代码和代码使用的变量(存储空间),在内核态就是内核为我们每个进程所保存的数据结构(状态信 ...

  5. 系统调用wait、waitpid和exec函数

    本文介绍了Linux下的进程的一些概念,并着重讲解了与Linux进程管理相关的重要系统调用wait,waitpid和exec函数族,辅助一些例程说明了它们的特点和使用方法. 1.7 背景 在前面的文章 ...

  6. linux c学习笔记----进程创建(fork,wait,waitpid)

    1.pid_t fork(); (1)当一个进程调用了fork 以后,系统会创建一个子进程.这个子进程和父进程不同的地方只有他的进程ID 和父进程ID,其他的都是一样.就象符进程克隆(clone)自己 ...

  7. 对while((pid = waitpid(-1, &stat, WNOHANG)) > 0)不懂的地方,现在懂了

    while((pid = waitpid(-1, &stat, WNOHANG)) > 0) 需要写到信号处理函数中,假如有10个子进程 只要父进程能够收到最后一个信号,就能把前面丢失的 ...

  8. wait、waitpid 僵尸进程 孤儿进程

    man wait: NAME wait, waitpid, waitid - wait for process to change state SYNOPSIS #include <sys/ty ...

  9. 进程控制之wait和waitpid函数

    当一个进程正常或异常终止时,内核就向其父进程发送SIGCHLD信号.因为子进程终止是个异步事件(这可以在父进程运行的任何时候发生),所以这种信号也是内核向父进程发的异步通知.父进程可以选择忽略该信号, ...

  10. 【转】linux : waitpid函数

    原文网址:http://blog.csdn.net/jifengszf/article/details/3067841 [waitpid系统调用]       功能描述: 等待进程改变其状态.所有下面 ...

随机推荐

  1. servlet的service特性就是http协议的特性 即连接完就断开

    servlet的service特性就是http协议的特性 即连接完就断开

  2. BZOJ4871 Shoi2017摧毁“树状图”(树形dp)

    设f[i][0/1/2/3/4/5]表示i子树中选一条链不包含根/i子树中选一条链包含根但不能继续向上延伸/i子树中选一条链可以继续向上延伸/选两条链不包含根/选两条链包含根但不能继续向上延伸/选两条 ...

  3. Python 源码剖析(一)【python对象】

    处于研究python内存释放问题,在阅读部分python源码,顺便记录下所得.(基于<python源码剖析>(v2.4.1)与 python源码(v2.7.6)) 先列下总结:      ...

  4. Bellman—Ford算法思想

    ---恢复内容开始--- Bellman—Ford算法能在更普遍的情况下(存在负权边)解决单源点最短路径问题.对于给定的带权(有向或无向)图G=(V,E),其源点为s,加权函数w是边集E的映射.对图G ...

  5. 2018牛客多校第四场 J.Hash Function

    题意: 给出一个已知的哈希表.求字典序最小的插入序列,哈希表不合法则输出-1. 题解: 对于哈希表的每一个不为-1的数,假如他的位置是t,令s = a[t]%n.则这个数可以被插入当且仅当第s ~ t ...

  6. Hyperledger Fabric 实战(十): Fabric node SDK 样例 - 投票DAPP

    Fabric node SDK 样例 - 投票DAPP 参考 fabric-samples 下的 fabcar 加以实现 目录结构 . ├── app │ ├── controllers │ │ └─ ...

  7. ArrayList动态扩容机制

    初始化:有三种方式 1.默认的构造器,将会以默认的大小来初始化内部的数组:public ArrayList(); 2.用一个ICollection对象来构造,并将该集合的元素添加到ArrayList: ...

  8. bzoj2120: 数颜色(BIT套主席树+set/分块)

    带修改的 HH的项链. 带修改考虑用BIT套主席树,查区间里有几个不同的数用a[i]上次出现的位置pre[i]<l的数有几个来算就好了. 考虑怎么修改.修改i的时候,我们需要改变i同颜色的后继的 ...

  9. [IOI2007]Miners 矿工配餐

    link 其实就是一个比较简单的$IOI$题.简单$dp$就行,设$5$维$dp$即可 最后在滚动一下,判一下可行性即可. #include<iostream> #include<c ...

  10. hdu 1166线段树 单点更新 区间求和

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...