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. 自定义锁屏图片 win7

    win + R打开运行对话框 输入Regedit 点确定 进入注册表,找到以下项次 HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersi ...

  2. [UE4]自定义服务器Service

  3. 让WordPress支持google AMP

    1.关于AMP 在移动互联网的时代,尽管网站响应式设计可以满足多屏(pc.手机.ipad等)浏览,但google在2015年10月推出了更快移动页面访问速度的技术-Accelerated Mobile ...

  4. Hadoop Api 基本操作

     hadoop环境配置好后,直接可以在window上进行调试.话不多说,直接上源码. package cn.terry; import java.io.FileInputStream; import ...

  5. MySQL存储过程中使用SELECT …INTO语句为变量赋值

    使用SELECT …INTO语句为变量赋值 在MySQL存储过程中,可以使用SELECT …INTO语句对变量进行赋值,该语句在数据库中进行查询,并将得到的结果赋值给变量.SELECT …INTO语句 ...

  6. 百度UEditor粘贴或插入的表格不显示边框的解决办法

    原文链接:http://blog.csdn.net/lovelyelfpop/article/details/51678742 参考:https://www.cnblogs.com/xiangsj/p ...

  7. Linux性能优化 第六章 性能工具:磁盘I/O

    6.1 磁盘I/O介绍 一般来说,Linux磁盘的每个分区要么包含一个文件系统,要么包含一个交换分区.这些分区被挂载到Linux根文件系统,该系统由/etc/fstab指定.这些被挂载的文件系统包含了 ...

  8. 插头DP模板

    /* 插头dp模板 抄的GNAQ 的 括号表示法 */ #include<cstdio> #include<algorithm> #include<cstring> ...

  9. python中的sockeserver模块简单实用

    1. socketserver模块简介 在python的socket编程中,实用socket模块的时候,是不能实现多个连接的,当然如果加入其它的模块是可以的,例如select模块,在这里见到的介绍下s ...

  10. linux:ubuntu安装mysql(一)

    1.下载MySQL安装包(MySQL Community Server) 地址:https://dev.mysql.com/downloads/mysql/ 2.解压 tar -xvf mysql-s ...