当前位置: 首页 > news >正文

kill子进程后再wait可以吗?

在父进程中先使用 kill 函数终止子进程,之后再使用 wait 函数是可行的,下面从原理、使用示例、注意事项几个方面详细说明。

原理

  • kill 函数:其作用是向指定进程发送信号。当向子进程发送 SIGTERM(通常用于请求进程正常终止)或者 SIGKILL(强制终止进程)这类终止信号时,子进程会收到信号并做出相应反应,一般会终止运行。子进程终止后,会进入僵尸状态,此时它虽然已经停止执行,但仍保留一些进程信息,等待父进程调用 wait 系列函数来回收这些资源。
  • wait 函数:父进程调用 wait 函数时,若有子进程处于僵尸状态,wait 函数会获取该子进程的终止状态信息,然后释放子进程占用的系统资源,将其从系统进程表中移除。

使用示例

以下代码展示了先使用 kill 函数终止子进程,再使用 wait 函数回收子进程资源的过程:

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <signal.h>

int main() {
    pid_t pid;
    int status;

    // 创建子进程
    pid = fork();

    if (pid < 0) {
        perror("fork");
        exit(EXIT_FAILURE);
    } else if (pid == 0) {
        // 子进程代码
        printf("子进程开始执行,进程ID: %d\n", getpid());
        while (1) {
            // 子进程进入无限循环,模拟长时间运行的任务
            sleep(1);
        }
    } else {
        // 父进程代码
        sleep(2);  // 等待一段时间,确保子进程开始执行
        printf("父进程发送 SIGTERM 信号终止子进程 %d\n", pid);
        // 向子进程发送 SIGTERM 信号
        if (kill(pid, SIGTERM) == -1) {
            perror("kill");
            exit(EXIT_FAILURE);
        }
        // 父进程等待子进程结束
        pid_t terminated_pid = wait(&status);
        if (terminated_pid == -1) {
            perror("wait");
            exit(EXIT_FAILURE);
        }
        if (WIFSIGNALED(status)) {
            printf("子进程 %d 因信号 %d 终止\n", terminated_pid, WTERMSIG(status));
        }
    }

    return 0;
}

代码解释

  1. 子进程:创建后进入一个无限循环,模拟长时间运行的任务。
  2. 父进程:等待 2 秒后,使用 kill 函数向子进程发送 SIGTERM 信号,请求子进程终止。然后调用 wait 函数等待子进程结束,并获取其终止状态信息。

注意事项

  • 信号处理:子进程可以捕获并处理 SIGTERM 信号,这意味着子进程可能不会立即终止。若需要强制终止子进程,可以使用 SIGKILL 信号,但要注意 SIGKILL 信号不能被捕获或忽略。
  • 错误处理:在调用 killwait 函数时,要检查其返回值,对可能出现的错误进行处理。例如,kill 函数可能因为权限不足或者目标进程不存在而调用失败。
  • 僵尸进程:若不调用 wait 函数回收子进程的资源,子进程会变成僵尸进程,占用系统资源。所以在终止子进程后,务必使用 wait 系列函数来回收资源。
http://www.dtcms.com/a/99500.html

相关文章:

  • java性能优化实例
  • 如何估算和优化 Gas
  • 学习通-操作系统第五版费翔林-习题-标答
  • 【AI学习】深度学习,人工神经网络
  • 破解美业数字化迷思:中小门店的智慧转型之路
  • 代码随想录day31 贪心part05
  • 蓝桥杯真题------R格式(高精度乘法,高精度加法)
  • Flutter 开发环境配置--宇宙级教学!
  • 【通道注意力机制】【SENet】Squeeze-and-Excitation Networks
  • 高并发系统下的订单号生成服务设计与实现
  • Node.js Express 安装并使用 nodemon
  • 多路径 TCP 调度的另一面
  • Vue3 事件处理
  • 英伟达GB300新宠:新型LPDDR5X SOCAMM内存
  • 【12】Ajax的原理和解析
  • C语言之链表增删查改
  • 【Java SE】Java比较器:Comparable、Comparator
  • Python的ASGI Web 服务器之uvicorn
  • 图解AUTOSAR_SWS_SynchronizedTimeBaseManager
  • Vue——常用指令总结、指令修饰符、v-model原理、computed计算属性、watch监听器、ref和$refs
  • JAVA反序列化深入学习(八):CommonsCollections6
  • python 上下文管理器with
  • CKS认证 | Day3 K8s容器运行环境安全加固
  • 实战篇Redis
  • 动力电池热失控:新能源汽车安全的“隐形火山”如何预防?
  • 蓝桥杯 之 二分
  • 8、linux c 信号机制
  • sass报错,忽略 Sass 弃用警告,降级版本
  • 笔记本裸机安装centos,找不到wifi设备问题
  • 英语学习笔记1