zoukankan      html  css  js  c++  java
  • 对while((pid = waitpid(-1, &stat, WNOHANG)) > 0)不懂的地方,现在懂了

    while((pid = waitpid(-1, &stat, WNOHANG)) > 0)

    需要写到信号处理函数中,假如有10个子进程

    只要父进程能够收到最后一个信号,就能把前面丢失的所产生的僵尸进程回收完.

    而父进程是能够收到最后一个信号的,就算父进程在子进程结束到第5个的时候,开始进行信号函数的处理.

    如果由于处理时间过长,导致剩下5个也在处理函数执行的过程中结束掉.这时,由于信号处理机制会导致剩下5个传递的信号会被阻塞,当然由于该信号不排队

    所以未决集只会有一个信号(当阻塞集相应位至1时,如果有相应信号到达,未决集至1,表示有未决的信号).至此,子进程已经全部结束,当信号函数执行完毕后,内核开放阻塞信号集,那么.之前被阻塞掉的那个信号传递进来.

    接下来再次回收剩下的僵尸进程.

    下面将给出代码,显示,信号函数的执行次数与回收次数的计数.就能看出区别

    void hander(int n)
    {
        static int i = 0;
        i++;
        printf("    i:%d
    ", i);
        while (waitpid(0, NULL, WNOHANG) > 0)
       	{
       		    static int j = 0;
        		j++;
        		printf("j:%d
    ", j);
       	}
           
    }
    

      

    waitpid(-1, &stat, WNOHANG)回收子进程,回收成功一个,返回子进程的pid,

    如果WNOHANG被指定,将不再阻塞回收,此时的返回规则是.如果有子进程,但没有结束(没有变成僵尸进程),waitpid返回0,如果有僵尸进程,回收一个僵尸进程,返回僵尸进程pid,所以要用循环去处理.把僵尸进程回收完

  • 相关阅读:
    python __init__.py
    估算小结
    ssh vim中不小心按下ctrl+s
    估算方法
    SSH 下使vim语法高亮显示 && 终端下vim配置
    not enough arguments for format string搞死人
    函数的形参 实参
    Linux 共享内存机制
    select函数参数及其使用
    找出两个字符串最长公共子串
  • 原文地址:https://www.cnblogs.com/c-slmax/p/5244425.html
Copyright © 2011-2022 走看看