wait函数等待多个子进程

父进程等待多个子进程时可以使用 wait() 函数,但有一些要点需要注意,下面为你详细介绍相关内容。

可以使用 wait() 函数等待多个子进程的原理

wait() 函数会让调用它的父进程暂停执行,直到它的某个子进程结束,然后返回结束子进程的进程ID,并将子进程的终止状态信息存储在 wstatus 参数指向的位置。要等待多个子进程,父进程可以循环调用 wait() 函数,每调用一次就等待一个子进程结束,直至所有子进程都结束。

示例代码

以下示例展示了如何使用 wait() 函数让父进程等待多个子进程结束:

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>

#define NUM_CHILDREN 3

int main() {
    pid_t pid;
    int i, status;

    // 创建多个子进程
    for (i = 0; i < NUM_CHILDREN; i++) {
        pid = fork();
        if (pid < 0) {
            perror("fork");
            exit(EXIT_FAILURE);
        } else if (pid == 0) {
            // 子进程代码
            printf("子进程 %d 开始执行,进程ID: %d\n", i + 1, getpid());
            sleep(1 + i);  // 模拟不同的执行时间
            printf("子进程 %d 执行完毕\n", i + 1);
            exit(i + 1);
        }
    }

    // 父进程等待所有子进程结束
    for (i = 0; i < NUM_CHILDREN; i++) {
        pid = wait(&status);
        if (pid == -1) {
            perror("wait");
            exit(EXIT_FAILURE);
        }
        if (WIFEXITED(status)) {
            printf("子进程 %d 已结束,退出状态码: %d\n", pid, WEXITSTATUS(status));
        }
    }

    return 0;
}

代码解释

  1. 创建多个子进程 :通过 for 循环调用 fork() 函数创建多个子进程。每个子进程会执行一些任务(这里用 sleep 函数模拟不同的执行时间),然后调用 exit() 函数退出,并设置自己的退出状态码。
  2. 父进程等待子进程 :父进程通过另一个 for 循环多次调用 wait() 函数,每次调用都会等待一个子进程结束。当 wait() 函数返回时,会输出结束子进程的进程ID和退出状态码。

使用 wait() 函数等待多个子进程的局限性

  • 顺序问题wait() 函数并不区分具体等待哪个子进程结束,它只是等待任意一个子进程结束。这意味着父进程无法按照特定的顺序等待子进程结束。
  • 错误处理较复杂:如果在等待过程中某个子进程因为信号中断等原因异常结束,需要仔细处理错误情况,确保所有子进程的资源都能被正确回收。

替代方案

可以考虑使用 waitpid() 函数,它能让父进程指定等待某个特定的子进程结束,或者按照一定的条件等待子进程结束,使用起来更加灵活。

相关推荐
硬核子牙1 分钟前
硬盘第一关:MBR VS GPT
linux
LCG元8 分钟前
Linux 日志分析全攻略:快速从海量日志中定位问题
linux
_Power_Y10 分钟前
Linux&git入门&设计模式(常考点)
linux·git·设计模式
海蓝可知天湛14 分钟前
Ubuntu24.10禁用该源...+vmware无法复制黏贴“天坑闭环”——从 DNS 诡异解析到 Ubuntu EOL 引发的 apt 404排除折腾记
linux·服务器·安全·ubuntu·aigc·bug
vvw&15 分钟前
如何在 Ubuntu 24.04 上安装和使用 AdGuard
linux·运维·服务器·ubuntu·adguard
遇见火星1 小时前
Linux 网络配置实战:RHEL/CentOS 7+ 永久静态路由配置与优先级调整全攻略
linux·网络·centos·静态路由·centos 7
程序员东岸1 小时前
数据结构精讲:从栈的定义到链式实现,再到LeetCode实战
c语言·数据结构·leetcode
say_fall1 小时前
C语言容易被忽略的易错点(2)
c语言·开发语言
下午见。2 小时前
深入理解C语言共用体/联合体(union):大小计算与大小端判断实战
c语言·笔记·学习
安审若无2 小时前
linux怎么检查磁盘是否有坏道
linux·运维·服务器