wait 和 waitpid 的区别(附有案例代码)

简介: wait 和 waitpid 的区别(附有案例代码)

一、wait 函数

#include <sys/types.h>
#include <sys/wait.h>
pid_t wait(int *wstatus);


功能:等待任意一个子进程结束,如果任意一个子进程结束了,该函数会回收子进程的资源。


参数:int *wstatus


      进程退出时的状态信息,传入的是一个int类型的地址(用于接收进程退出时的状态信息),传出参数。


返回值:


       - 成功:返回被回收的子进程的id


       - 失败:-1 (所有的子进程都结束,调用函数失败)


      调用wait函数的进程会被挂起(阻塞),直到它的一个子进程退出或者收到一个不能被忽略的信号时才被唤醒(相当于继续往下执行);如果没有子进程了,函数立刻返回,返回-1;如果子进程都已经结束了,也会立即返回,返回-1。


#include <sys/types.h>
#include <sys/wait.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int main() {
    // 有一个父进程,创建5个子进程(兄弟)
    pid_t pid;
    // 创建5个子进程
    for(int i = 0; i < 5; i++) {
        pid = fork();
        if(pid == 0) {
            break;
        }
    }
    if(pid > 0) {
        // 父进程
        while(1) {
            printf("parent, pid = %d\n", getpid());
            // int ret = wait(NULL);
            int st;
            int ret = wait(&st);
            if(ret == -1) {
                break;
            }
            if(WIFEXITED(st)) {
                // 是不是正常退出
                printf("退出的状态码:%d\n", WEXITSTATUS(st));
            }
            if(WIFSIGNALED(st)) {
                // 是不是异常终止
                printf("被哪个信号干掉了:%d\n", WTERMSIG(st));
            }
            printf("child die, pid = %d\n", ret);
            sleep(1);
        }
    } else if (pid == 0){
        // 子进程
         while(1) {
            printf("child, pid = %d\n",getpid());    
            sleep(1);       
         }
        exit(0);
    }
    return 0; // exit(0)
}


二、waitpid 函数


#include <sys/types.h>
#include <sys/wait.h>
pid_t waitpid(pid_t pid, int *wstatus, int options);


功能:回收指定进程号的子进程,可以设置是否阻塞。


参数:


       - pid:


               pid > 0 : 某个子进程的pid


               pid = 0 : 回收当前进程组的所有子进程,一个进程组中可能包含多个进程    


               pid = -1 : 回收所有的子进程,相当于 wait()  (最常用)


               pid < -1 : 进程组的组 id 的绝对值,回收指定进程组中的所有子进程


       - int *wstatus


              进程退出时的状态信息,传入的是一个int类型的地址(用于接收进程退出时的状态信                息),传出参数


      - options:设置阻塞或者非阻塞


               0 : 阻塞


               WNOHANG : 非阻塞


      - 返回值:


               > 0 : 返回子进程的id


               = 0 : options=WNOHANG, 表示还有子进程活着


               = -1 :错误,或者没有子进程了


#include <sys/types.h>
#include <sys/wait.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int main() {
    // 有一个父进程,创建5个子进程(兄弟)
    pid_t pid;
    // 创建5个子进程
    for(int i = 0; i < 5; i++) {
        pid = fork();
        if(pid == 0) {
            break;
        }
    }
    if(pid > 0) {
        // 父进程
        while(1) {
            printf("parent, pid = %d\n", getpid());
            sleep(1);
            int st;
            // int ret = waitpid(-1, &st, 0);
            int ret = waitpid(-1, &st, WNOHANG);
            if(ret == -1) {
                break;
            } else if(ret == 0) {
                // 说明还有子进程存在
                continue;
            } else if(ret > 0) {
                if(WIFEXITED(st)) {
                    // 是不是正常退出
                    printf("退出的状态码:%d\n", WEXITSTATUS(st));
                }
                if(WIFSIGNALED(st)) {
                    // 是不是异常终止
                    printf("被哪个信号干掉了:%d\n", WTERMSIG(st));
                }
                printf("child die, pid = %d\n", ret);
            }
        }
    } else if (pid == 0){
        // 子进程
         while(1) {
            printf("child, pid = %d\n",getpid());    
            sleep(1);       
         }
        exit(0);
    }
    return 0; 
}


相关文章
|
存储 缓存 JSON
Unity资源热更新知识梳理及工作流介绍
研究了大半年的热更,才做出了一套相对完善的热更架构。不得不说,这块的知识点还是多而杂的,值得专门开篇博文来记录梳理。
3168 0
|
算法 Linux C++
【Linux系统编程】Linux目录操作:opendir、readdir与closedir详解
【Linux系统编程】Linux目录操作:opendir、readdir与closedir详解
888 0
|
机器学习/深度学习 人工智能 算法
现身说法,AI小白的大模型学习路径
写这篇文章的初衷:作为一个AI小白,把我自己学习大模型的学习路径还原出来,包括理解的逻辑、看到的比较好的学习材料,通过一篇文章给串起来,对大模型建立起一个相对体系化的认知,才能够在扑面而来的大模型时代,看出点门道。
1443 79
|
移动开发 JavaScript 前端开发
html table+css实现可编辑表格的示例代码
html table+css实现可编辑表格的示例代码
425 12
|
Shell Linux C语言
Linux0.11 execve函数(六)
Linux0.11 execve函数(六)
635 1
|
机器学习/深度学习 运维 自然语言处理
探索机器学习在金融欺诈检测中的应用
【5月更文挑战第3天】 随着金融科技的迅猛发展,机器学习作为其核心推动力之一,正逐渐改变着我们对金融服务安全与效率的理解。本文将深入探讨机器学习技术在金融欺诈检测领域内的应用现状与前景。通过分析多种算法和实际案例,我们揭示了如何利用机器学习提高识别欺诈行为的准确率,降低金融机构的风险损失。同时,文章还将讨论在此过程中遇到的挑战及未来的发展趋势,为读者提供一个全面而深入的视角。
|
定位技术
Flutter笔记:缩放手势
Flutter笔记:缩放手势
432 0
|
前端开发 JavaScript 定位技术
Flutter vs 前端 杂谈:SliverAppBar、手动实现Appbar、前端Html+JS怎么实现滚动变化型Appbar - 比较
Flutter vs 前端 杂谈:SliverAppBar、手动实现Appbar、前端Html+JS怎么实现滚动变化型Appbar - 比较
351 0
|
机器学习/深度学习 人工智能 运维
运维的未来发展趋势包括以下几个方面
运维的未来发展趋势包括以下几个方面
1235 1
|
数据库 vr&ar
关系数据库——关系代数
关系数据库——关系代数
679 0