• 对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,所以要用循环去处理.把僵尸进程回收完

  • 相关阅读:
    Jenkins Install
    提高C#代码质量的22条准则
    游戏程序员英文指南
    苹果设备内存指南
    Unity符号表
    UI优化策略-UI性能优化技巧
    C# 语言历史版本特性
    CPU SIMD介绍
    Unity渲染性能指标
    关于JMeter线程组中线程数,Ramp-Up Period,循环次数之间的设置概念
  • 原文地址:https://www.cnblogs.com/c-slmax/p/5244425.html
Copyright © 2020-2023  润新知