waitpid函数:作用同wait,但可指定pid进程清理,可以不阻塞。

原型:pid_t waitpid(pid_t pid, int *status, in options);

返回值:成功时返回清理掉的子进程ID,失败返回-1;当第三个参数被设置为WNOHANG,且子进程还在运行时,返回0;

参数说明:

pid

> 0 回收指定ID的子进程  。

-1 回收任意子进程(相当于wait)

0 回收和当前调用waitpid一个组的所有子进程。

< -1 回收指定进程组内的任意子进程。

status

存储进程死亡的信息。

options

设置为阻塞或者不阻塞状态。

WNOHANG:不阻塞

0:阻塞

现在有一个题目:父进程fork 3 个子进程,三个子进程一个调用ps命令, 一个调用自定义程序1(正常),一个调用自定义程序2(会出段错误)。父进程使用waitpid对其子进程进行回收。

很简单,就是一些函数的调用。

代码:

#include
<cstdio>

#include
<unistd.h>

#include
<stdlib.h>

#include
<sys/types.h>

#include
<sys/wait.h>

 

int main()

{

    int i = 0;

    int status; //存储进程死亡信息

    pid_t pid; //存储wait函数返回值

 

    for (; i != 3; i++)

    {

        if (!fork())

        {

            break;

        }

    }

    if (i < 3)

    {

        if (0 == i)

        {

            int e_ret = execlp("ps", "ps", "aux", NULL);

            if (-1 == e_ret)

            {

                perror("execlp ps error ");

                exit(1);

            }

        }

        else
if (1 == i)

        {

            int e_ret = execl(" / home / lovedan / projects / test / a", "a", NULL);

            if (-1 == e_ret)

            {

                perror("execlp a error ");

                exit(1);

            }

        }

        else
if (2 == i)

        {

            int e_ret = execl(" / home / lovedan / projects / test / b", "b", NULL);

            if (-1 == e_ret)

            {

                perror("execlp b error ");

                exit(1);

            }

        }

    }

    else
if (i == 3)

    {

        //while (-1 != (pid = waitpid(-1, &status, WNOHANG)))//这里设置为不阻塞状态

        while (-1 != (pid = wait(&status))) //上面那句代码并没有问题。不阻塞的话,那输出真的是群魔乱舞。

        {

            if (0 == pid)

            {

                printf("The child process is running and does not recycle.\n");

            }

            else
if (pid > 0)

            {

                printf("The recovery sub - process is successful, and his ID is %d .\n", pid);

                if (WIFEXITED(status))

                {

                    printf("The subprocess exits normally, and the return value is %d .\n", WEXITSTATUS(status));

                }

                else
if (WIFSIGNALED(status))

                {

                    printf("The subprocess exits with an exception because it exits with a signal of %d .\n", WTERMSIG(status));

                }

            }

        }

        if (-1 == pid)

        {

            printf("No child processes can be recycled.\n");

        }

    }

    else

    {

        printf("i value error.i = %d", i);

        exit(1);

    }

 

    // printf("hello from fork_3_ps_normal_SegmentationFault!\n");

    return 0;

}

程序中的a和b是另外的两个小程序,根据题目意思来写的,很简单,代码就不拿上来了。

来看看不阻塞和阻塞状态下的输出:首先是不阻塞的;

The child process is running and does not recycle.

The child process is running and does not recycle.

The child process is running and does not recycle.

The child process is running and does not recycle.

I am a.

The recovery sub-process is successful, and his ID is 449 .

The subprocess exits with an exception because it exits with a signal of 11 .

The recovery sub-process is successful, and his ID is 448 .

The subprocess exits normally, and the return value is 216 .

The child process is running and does not recycle.

The child process is running and does not recycle.

The child process is running and does not recycle.

The child process is running and does not recycle.

USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND

The child process is running and does not recycle.

The child process is running and does not recycle.

root         1  0.0  0.0  10432   580 ?        Ss   08:29   0:00 /init

The child process is running and does not recycle.

The child process is running and does not recycle.

The child process is running and does not recycle.

The child process is running and does not recycle.

lovedan      2  0.0  0.0  25788  3704 tty1     Ss   08:29   0:00 -bash

The child process is running and does not recycle.

root        44  0.0  0.0  80408   912 ?        Ss   08:30   0:00 /usr/sbin/sshd

The child process is running and does not recycle.

lovedan    446  0.0  0.0  36172   516 tty1     S    09:06   0:00 ./fork_3_ps_normal_SegmentatThe child process is running and does not recycle.

lovedan    447  0.0  0.0  51704  1832 tty1     R    09:06   0:00 ps aux

The child process is running and does not recycle.

The recovery sub-process is successful, and his ID is 447 .

The subprocess exits normally, and the return value is 0 .

No child processes can be recycled.

完全是群魔乱舞。

来看看阻塞状态下的:

I am a.

The recovery sub-process is successful, and his ID is 727 .

The subprocess exits normally, and the return value is 216 .

The recovery sub-process is successful, and his ID is 728 .

The subprocess exits with an exception because it exits with a signal of 11 .

USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND

root         1  0.0  0.0  10432   580 ?        Ss   08:29   0:00 /init

lovedan      2  0.0  0.0  25788  3708 tty1     Ss   08:29   0:00 -bash

root        44  0.0  0.0  80408   912 ?        Ss   08:30   0:00 /usr/sbin/sshd

lovedan    725  0.0  0.0  36172   512 tty1     S    09:10   0:00 ./fork_3_ps_normal_SegmentationFault.out

lovedan    726  0.0  0.0  51704  1832 tty1     R    09:10   0:00 ps aux

The recovery sub-process is successful, and his ID is 726 .

The subprocess exits normally, and the return value is 0 .

No child processes can be recycled.

这就比较好了。满足。

用waitpid函数回收进程的更多相关文章

  1. wait/waitpid函数与僵尸进程、fork 2 times

    一.僵尸进程 当子进程退出的时候,内核会向父进程发送SIGCHLD信号,子进程的退出是个异步事件(子进程可以在父进程运行的任何时刻终止) 子进程退出时,内核将子进程置为僵尸状态,这个进程称为僵尸进程, ...

  2. 【Linux】僵尸进程,孤儿进程以及wait函数,waitpid函数(有样例,分析很详细)

    本文内容: 1.僵尸进程,孤儿进程的定义,区别,产生原因,处理方法 2.wait函数,waitpid函数的分析,以及比较 背景:由于子进程的结束和父进程的运行是一个异步的过程,即父进程永远无法预测子进 ...

  3. linux多进/线程编程(3)——wait、waitpid函数和孤儿、僵尸进程

    当使用fork创建多个进程后,需要解决子进程回收的问题.wait和waitpid函数就是做这个工作的. 假设子进程没有合理的回收,可能会带来两个问题: 1.孤儿进程(父进程挂了,子进程活着),孤儿进程 ...

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

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

  5. 回收进程用户空间资源 exit()函数 _exit()函数 atexit()函数 on_exit()函数

    摘要:本文主要讲述进程的终止方式,以及怎样使用exit()函数来终止进程.回收进程用户空间资源:分析了exit()函数与_exit()函数,returnkeyword的差异.同一时候具体解读了怎样使用 ...

  6. UNIX环境编程学习笔记(21)——进程管理之获取进程终止状态的 wait 和 waitpid 函数

    lienhua342014-10-12 当一个进程正常或者异常终止时,内核就向其父进程发送 SIGCHLD信号.父进程可以选择忽略该信号,或者提供一个该信号发生时即被调用的函数(信号处理程序).对于这 ...

  7. wait函数与waitpid函数(僵尸进程)

    当子进程退出时,内核会向父进程发送SIGCHLD信号,子进程的退出是个异步事件(子进程可以在父进程运行的任何时刻终止) 子进程退出时,内核将子进程置为僵尸状态,这个进程称为僵尸进程.它只保留最小的一些 ...

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

    僵尸进程:子进程终止了,但是父进程没有回收子进程的资源PCB.使其成为僵尸进程 孤儿进程:父进程先与子进程结束了,使得子进程失去了父进程,这个时候子进程会被1号进程init进程领养,成为孤儿进程 为了 ...

  9. waitpid()函数

    waitpid函数 作用同于wait,但可指定pid进程清理,可以不阻塞. pid_t waitpid(pid_t pid,int *status,int options);成功:返回清理掉的子进程I ...

随机推荐

  1. go语言学习--map类型的切片

    今天在项目中遇到了一个切片的map,记录下map切片的使用 package main import "fmt" func main() { // Version A: items ...

  2. 一次聊天引发的思考--java并发包

    一次聊天,谈到了死锁的解决.可重入锁等等,突然发现这些离自己很远,只有一些读书时的概念涌入脑海,但各自的应用场景怎么都无法想出.痛定思痛,决定看看concurrent包里涉及并发的类及各自的应用场景. ...

  3. Linux常用指令之一

    1.基础命令 ls --查看当前目录下的文件     cd --切换目录或者直接回到home目录     cd - --切换最近使用的两次目录     cd .. --切换到上一级目录     pwd ...

  4. MyBatis 工作原理

    参考链接: 深入理解Mybatis原理:http://blog.csdn.net/luanlouis/article/details/40422941 MyBatis原理:http://www.jia ...

  5. Hibernate c3p0的整合

    Hibernate整合c3p0 Hibernate中可以使用默认jdbc连接池,但是无论功能还是性能都不如c3p0 在pom添加jar包: <!-- hibernate-c3p0 --> ...

  6. 使用dtc把dtb的反编译为dts

    sudo apt-get install device-tree-compiler dtc -I dtb -O dts msm8976-v1.1-qrd.dtb > msm8976-v1.1-q ...

  7. gcc 工作流程

    gcc常用参数: 1:-v/--version 2:-I :指定头文件包含路径 3:-c :将汇编文件生成一个二级制文件,得到.o文件 4:-o :指定生产的文件名 5:-g :gdb调试的时候需要加 ...

  8. NodeJs安装以及注意事项

    1.测试NodeJs是否安装成功 node --version npm -v 配置node的可执行文件路径到环境变量path 2.安装相关环境 npm install express -g npm i ...

  9. Oracle Service Bus (OSB) 12c 的配置安装

    Oracle Service Bus (OSB) 12c 的配置安装 1.OSB配置环境: Oracle Database Oracle Fusion Middleware Infrastructur ...

  10. 各种uml图

    UML各种图总结-精华   UML(Unified Modeling Language)是一种统一建模语言,为面向对象开发系统的产品进行说明.可视化.和编制文档的一种标准语言.下面将对UML的九种图+ ...