news 2026/7/3 21:09:18

父子进程关系与终止机制详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
父子进程关系与终止机制详解

父子进程关系与终止机制

父子进程关系子进程通过fork()系统调用创建,是父进程的副本。现代Linux内核(如Ubuntu 18的Linux 5.4)采用写时复制(Copy-On-Write, COW)技术:子进程初始共享父进程的内存空间,仅当任一进程尝试修改共享数据时,内核才会为子进程分配独立的内存副本。这优化了性能,避免了不必要的内存复制。

进程终止的8种情况

  • 正常终止:
    • main()函数中执行return语句。
    • 调用C库函数exit(),会清理I/O缓冲区、关闭文件流、执行atexit()注册的函数。
    • 调用系统调用_exit(),直接终止进程但不清理缓冲区或执行atexit()函数。
    • 主线程退出或调用pthread_exit()
  • 异常终止:
    • 调用abort()触发SIGABRT信号。
    • 通过信号(如kill命令发送SIGKILL)终止进程。
    • 最后一个线程被pthread_cancel()取消。

僵尸进程与孤儿进程

僵尸进程
子进程终止后,其PCB(进程控制块)未被父进程回收(通过wait()waitpid()),导致内核资源泄漏。长期运行的父进程若频繁创建短生命周期子进程,可能导致系统资源耗尽。

孤儿进程
父进程先于子进程终止时,子进程被init进程(PID 1)接管,由init负责后续回收,无需额外处理。

进程退出函数对比

exit()_exit()

  • exit(int status)
    • 库函数,终止进程并执行清理(刷新缓冲区、调用atexit()注册的函数)。
    • 参数status传递退出状态(EXIT_SUCCESSEXIT_FAILURE)。
  • _exit(int status)
    • 系统调用,立即终止进程,不执行任何清理。
    • 适用于需要快速退出的场景(如子进程异常处理)。

执行顺序
exit()→ 刷新缓冲区 → 执行atexit()注册函数 → 调用_exit()

进程资源回收

wait()函数

pid_t wait(int *status);
  • 阻塞等待任意子进程退出,并回收其资源。
  • status参数存储子进程退出状态,可通过宏解析:
    • WIFEXITED(status):判断是否正常退出。
    • WEXITSTATUS(status):获取正常退出的返回值。
    • WIFSIGNALED(status):判断是否因信号终止。
    • WTERMSIG(status):获取终止信号的编号。

示例代码

int status; pid_t pid = wait(&status); if (WIFEXITED(status)) { printf("Child exited with status %d\n", WEXITSTATUS(status)); } else if (WIFSIGNALED(status)) { printf("Child killed by signal %d\n", WTERMSIG(status)); }

关键注意事项

  • 长期运行的父进程必须主动回收子进程,避免僵尸进程累积。
  • exit()_exit()的选择需根据清理需求决定。
  • 信号处理中若需立即终止进程,优先使用_exit()以避免缓冲区操作未完成的问题。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/2 8:15:29

Product Hunt 每日热榜 | 2025-12-14

1. PlanEat AI 标语:人工智能将你的健康目标变成一个为期7天的菜单和购物清单。 介绍:大多数应用程序给你提供一堆食谱,而聊天机器人则让你淹没在文字中。PlanEat AI 将你的健康数据和饮食规则整理成一个可行的每周计划和分类购物清单&…

作者头像 李华
网站建设 2026/7/3 9:31:24

实验实验实验

这玩意儿直接html吗,前端和后端直接连接,直接打包。我可以理解为这是专属小程序的debug,必须要有源代码。

作者头像 李华
网站建设 2026/7/2 5:58:43

二叉搜索树详解:从原理到实战

文章目录一、什么是二叉搜索树(BST)?二、BST 的基本操作1. 节点定义2. 查找操作3. 插入操作4. 删除操作三、经典例题分析例题 1:验证二叉搜索树(LeetCode 98)例题 2:二叉搜索树的最近公共祖先&a…

作者头像 李华
网站建设 2026/7/1 20:05:00

后端学习第二周

IO流 IO流: 存储和读取数据的解决方案用于读写文件中的数据(可以读写文件,或网络中的数据…)输入流读取本地文件中的数据,输出本地文件中的数据 字节(符)输入流负责读取数据,字节&am…

作者头像 李华
网站建设 2026/7/4 1:56:12

10-2 phase:run_test UVM测试平台层次结构与Phase执行顺序解析

10-1 phase:basic UVM测试平台层次结构与Phase执行顺序解析 这个案例和上一篇10-1基本类似,可以跳过,区别是这个案例少了上篇很奇怪的AA类的中间层 文章目录 ✅ 区别总结:代码1 与 代码2 的核心差异 UVM Phase执行顺序的准确解析:组件层次结构对执行顺序的影响 一、核心问…

作者头像 李华