Linux系统编程之进程创建
概述
在Linux系统中,通过创建新的进程,我们可以实现多任务处理、并发执行和资源隔离等功能。创建进程的主要方法为:fork、vfork、clone。下面,我们将分别进行介绍。
fork
fork是最常用的创建新进程的方法。当一个进程调用fork时,系统会创建一个新的子进程。子进程是调用进程(即父进程)的一个精确副本,但它有自己的独立内存空间、文件描述符等资源。fork使用写时拷贝技术,以推迟或避免不必要的拷贝。在需要写入时,才会复制地址空间。fork函数返回两次:一次是在父进程中返回子进程的PID,另一次是在子进程中返回0。fork函数的原型如下。
pid_t fork(void);
fork函数是一个无参函数,调用时不需要传递任何参数。返回值取决于调用的结果和当前进程的状态,有以下三种情况。
1、父进程。当fork函数调用成功时,父进程会收到子进程的PID。这个PID是一个唯一的正整数,用于标识子进程。父进程可以使用这个PID来监控子进程的状态,比如:通过wait或waitpid等函数等待子进程结束。
2、子进程。子进程在调用fork函数后,会立即返回0。这是因为子进程需要知道自己是新创建的进程,而0是一个特殊的返回值,专门用于标识子进程。子进程从fork函数返回后,通常会执行与父进程不同的任务,或者调用exec系列函数来执行新的程序。
3、错误处理。如果fork函数调用失败,它会返回-1,并设置全局变量errno来表示具体的错误原因。常见的错误包括:系统资源不足、内存不足等。
具体如何使用fork,可参考下面的示例代码。
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>int main()
{// 创建子进程pid_t pid = fork();if (pid < 0){// 创建子进程失败printf("Fork failed!\n");return 1;}else if (pid == 0){// 如果返回0,表示当前代码在子进程中执行printf("Hello from child process\n");}else{// 如果返回正值,表示当前代码在父进程中执行,返回值为子进程IDprintf("Hello from parent process. Child PID: %d\n", pid);}// 父子进程都会执行到这里return 0;
}
vfork
vfork函数与fork类似,其函数原型如下。
pid_t vfork(void);
vfork函数与fork有一些重要的区别,主要有如下几点。
1、内存共享。
fork:创建的新进程是父进程的一个完全复制,子进程拥有自己独立的内存空间、文件描述符等资源。子进程和父进程之间没有任何内存共享,因此子进程可以安全地修改自己的内存而不影响父进程。
vfork:创建的新进程与父进程共享内存,子进程在自己的地址空间中运行,但实际上与父进程共享同一个内存地址空间。子进程不能修改任何数据结构,因为这些修改会影响到父进程。因此,子进程必须尽快调用exec系列函数来执行新的程序,或者调用_exit函数退出。
2、父进程的阻塞。
fork:父进程和子进程几乎同时开始执行。父进程在fork返回后可以立即继续执行,子进程也从fork返回点开始执行。父进程和子进程之间的执行顺序是不确定的,取决于操作系统的调度策略。
vfork:父进程在子进程调用exec或_exit之前,会被阻塞。这意味着父进程会暂停执行,直到子进程完成exec或_exit。这种设计减少了内存开销,因为子进程不需要复制父进程的整个内存空间。
3、使用场景。
fork:适用于需要创建一个完全独立的子进程的场景。子进程可以执行与父进程不同的任务,或者调用exec系列函数来执行新的程序。由于子进程是父进程的完全复制,因此fork比较消耗资源,特别是当父进程占用大量内存时。
vfork:适用于需要临时借用父进程的地址空间来执行exec系列函数的场景。这种情况下,子进程不需要长时间运行,只需要快速切换到新的程序。vfork更节省资源,因为它不需要复制父进程的内存空间,但同时也带来了更多的限制,因为子进程不能修改任何数据结构。
clone
与fork和vfork不同,clone函数提供了更多的灵活性。它允许用户指定哪些资源应该被共享,从而可以创建线程或更轻量级的进程。其函数原型如下。
int clone(int (*fn)(void *), void *child_stack, int flags, void *arg, ... /* pid_t *ptid, struct user_desc *tls, pid_t *ctid */ );
fn:指向子进程将要执行的函数的指针,子进程从这个函数开始执行。函数的返回值是一个整数,通常用于表示子进程的退出状态。
child_stack:指向子进程栈的指针,子进程将使用这块内存作为其栈空间。通常,这块内存是从堆中分配的,且指向栈的顶部(即高地址)。
flags:一个位掩码,用于指定子进程的行为和资源共享方式,可取值为CLONE_VM、CLONE_FILES等。
arg:指向传递给fn函数的参数的指针。
ptid:可选参数,指向一个变量,该变量将存储子进程的PID。
tls:可选参数,指向线程局部存储TLS描述符。
ctid:可选参数,指向一个变量,该变量将接收子进程的CTID(如果设置了CLONE_CHILD_SETTID标志)。
由于clone函数提供了更多的选项,因此使用起来也更加复杂。开发者需要详细了解各个标志位的作用,并正确管理栈空间和其他资源。虽然可以直接使用clone创建线程,但这通常只在特定的高性能或低级系统编程场景中才会用到。
相关文章:
Linux系统编程之进程创建
概述 在Linux系统中,通过创建新的进程,我们可以实现多任务处理、并发执行和资源隔离等功能。创建进程的主要方法为:fork、vfork、clone。下面,我们将分别进行介绍。 fork fork是最常用的创建新进程的方法。当一个进程调用fork时&a…...

JAVA-IO
目录 IO流 一 字节流 1 FileOutStream 1 书写: 2 换行书写与续写: 2 FileInputStream 1 读取数据 2 循环读取: 二 字符流 1 FileReader 1 空参的read()方法读取数据: 2 有参的read()方法读取数据: 3 指定字…...
动态系统特征分析:特征向量、特征值、频率与阻尼比、参与因子计算方法
特征值和特征向量在动态系统分析中是核心工具,广泛用于电力系统小信号稳定性、机械系统模态分析等领域。以下详细介绍计算方法及应用。 1. 求解特征值与特征向量 对于一个 n n n\times n nn的系统矩阵 A A A: 右特征向量与特征值 特征值( λ \lambd…...

乐鑫发布 esp-iot-solution v2.0 版本
今天,乐鑫很高兴地宣布,esp-iot-solution v2.0 版本已经发布,release/v2.0 分支下的正式版本组件将为用户提供为期两年的 Bugfix 维护(直到 2027.01.25 ESP-IDF v5.3 EOL)。该版本将物联网开发中常用的功能进行了分类整…...

动态代理如何加强安全性
在当今这个信息爆炸、网络无孔不入的时代,我们的每一次点击、每一次浏览都可能留下痕迹,成为潜在的安全隐患。如何在享受网络便利的同时,有效保护自己的隐私和信息安全,成为了每位网络使用者必须面对的重要课题。动态代理服务器&a…...
Flutter 之 InheritedWidget
InheritedWidget 是 Flutter 框架中的一个重要类,用于在 Widget 树中共享数据。它是 Flutter 中数据传递和状态管理的基础之一。通过 InheritedWidget,你可以让子 Widget 在不需要显式传递数据的情况下,访问祖先 Widget 中的数据。这种机制对…...

AI 助力开发新篇章:云开发 Copilot 深度体验与技术解析
本文 一、引言:技术浪潮中的个人视角1.1 AI 和低代码的崛起1.2 为什么选择云开发 Copilot? 二、云开发 Copilot 的核心功能解析2.1 自然语言驱动的低代码开发2.1.1 自然语言输入示例2.1.2 代码生成的模块化支持 2.2 实时预览与调整2.2.1 实时预览窗口功能…...
MyBatis-Plus介绍及基本使用
文章目录 概述介绍MyBatis-Plus 常用配置分页插件配置类注解配置 快速入门maven 依赖编写配置文件编写启动类编写 MybatisPlus 配置类 代码生成器:MybatisPlusGeneratormaven依赖代码生成器核心类 概述 介绍 MyBatis-Plus(简称 MP)是一个 M…...

SpringBoot 整合 Avro 与 Kafka
优质博文:IT-BLOG-CN 【需求】:生产者发送数据至 kafka 序列化使用 Avro,消费者通过 Avro 进行反序列化,并将数据通过 MyBatisPlus 存入数据库。 一、环境介绍 【1】Apache Avro 1.8;【2】Spring Kafka 1.2…...
支持JT1078和GB28181的流媒体服务器-LKM启动配置文件参数说明
流媒体服务器地址:https://github.com/lkmio/lkm GB28181信令,模拟多个国标设备工具:https://github.com/lkmio/gb-cms 文章目录 gop_cachegop_buffer_sizeprobe_timeoutwrite_timeoutmw_latencylisten_ippublic_ipidle_timeoutreceive_timeo…...
什么是隐式类型转换?隐式类型转换可能带来哪些问题? 显式类型转换(如强制类型转换)有哪些风险?
C 中的隐式类型转换 定义:在 C 中,隐式类型转换是指由编译器自动执行的类型转换,不需要程序员显式地进行操作。这种转换在很多情况下会自动发生,比如在表达式求值、函数调用传参等过程中。常见场景 算术运算中的转换:…...
量化交易新利器:阿布量化(AbuQuant)——金融研究者的得力助手
🚀 量化交易新利器:阿布量化(AbuQuant)——金融研究者的得力助手 🚀 文章目录 🚀 量化交易新利器:阿布量化(AbuQuant)——金融研究者的得力助手 🚀dz…...
UI设计从入门到进阶,全能实战课
课程内容: ├── 【宣导片】从入门到进阶!你的第一门UI必修课!.mp4 ├── 第0课:UI知识体系梳理 学习路径.mp4 ├── 第1课:IOS设计规范——基础规范与切图.mp4 ├── 第2课:IOS新趋势解析——模块规范与设计原则(上).mp4…...
Uniapp自动调整元素高度
获取设备的像素 如果你想让元素的高度相对于整个屏幕的高度占用一定的比例,可以通过获取屏幕的高度,然后计算出你想要的比例来设置元素的高度。以下是如何实现的示例: <script setup> import { ref, onMounted } from vue;// 定义一个…...

软考高项经验分享:我的备考之路与实战心得
软考,尤其是信息系统项目管理师(高项)考试,对于众多追求职业提升与专业认可的人士来说,是一场充满挑战与机遇的征程。我在当年参加软考高项的经历,可谓是一波三折,其中既有成功的喜悦࿰…...

安全关系型数据库查询新选择:Rust 语言的 rust-query 库深度解析
在当今这个数据驱动的时代,数据库作为信息存储和检索的核心组件,其重要性不言而喻。然而,对于开发者而言,如何在保证数据安全的前提下,高效地进行数据库操作却是一项挑战。传统的 SQL 查询虽然强大,但存在诸…...
《C++ 模型训练之早停法:有效预防过拟合的关键策略》
在 C 模型开发的复杂世界里,过拟合犹如一个潜藏的陷阱,常常使我们精心构建的模型在实际应用中表现大打折扣。而早停法(Early Stopping)作为一种行之有效的策略,能够帮助我们及时察觉模型训练过程中的异常,避…...

5.11【数据库】第一次实验
民宿预定,至少有不同的民宿,民宿下面有不同的房间(面积,房间编号) 房间类型,单价, 可预订以及不可预订 游客信息 订单信息 公司有很多课程, 学生,课程 每位学生每期…...

【CSS in Depth 2 精译_062】第 10 章 CSS 中的容器查询(@container)概述 + 10.1 容器查询的一个简单示例
当前内容所在位置(可进入专栏查看其他译好的章节内容) 【第十章 CSS 容器查询】 ✔️ 10.1 容器查询的一个简单示例 ✔️ 10.1.1 容器尺寸查询的用法 ✔️ 10.2 深入理解容器10.3 与容器相关的单位10.4 容器样式查询的用法10.5 本章小结 文章目录 第 10…...

蓝桥杯每日真题 - 第23天
题目:(直线) 题目描述(12届 C&C B组C题) 解题思路: 题目理解: 在平面直角坐标系中,从给定的点集中确定唯一的直线。 两点确定一条直线,判断两条直线是否相同,可通过…...

【kafka】Golang实现分布式Masscan任务调度系统
要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...

2025年能源电力系统与流体力学国际会议 (EPSFD 2025)
2025年能源电力系统与流体力学国际会议(EPSFD 2025)将于本年度在美丽的杭州盛大召开。作为全球能源、电力系统以及流体力学领域的顶级盛会,EPSFD 2025旨在为来自世界各地的科学家、工程师和研究人员提供一个展示最新研究成果、分享实践经验及…...

大数据零基础学习day1之环境准备和大数据初步理解
学习大数据会使用到多台Linux服务器。 一、环境准备 1、VMware 基于VMware构建Linux虚拟机 是大数据从业者或者IT从业者的必备技能之一也是成本低廉的方案 所以VMware虚拟机方案是必须要学习的。 (1)设置网关 打开VMware虚拟机,点击编辑…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

Nuxt.js 中的路由配置详解
Nuxt.js 通过其内置的路由系统简化了应用的路由配置,使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

Mac软件卸载指南,简单易懂!
刚和Adobe分手,它却总在Library里给你写"回忆录"?卸载的Final Cut Pro像电子幽灵般阴魂不散?总是会有残留文件,别慌!这份Mac软件卸载指南,将用最硬核的方式教你"数字分手术"࿰…...
【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分
一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计,提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合:各模块职责清晰,便于独立开发…...

Redis数据倾斜问题解决
Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中,部分节点存储的数据量或访问量远高于其他节点,导致这些节点负载过高,影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...

如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...
Angular微前端架构:Module Federation + ngx-build-plus (Webpack)
以下是一个完整的 Angular 微前端示例,其中使用的是 Module Federation 和 npx-build-plus 实现了主应用(Shell)与子应用(Remote)的集成。 🛠️ 项目结构 angular-mf/ ├── shell-app/ # 主应用&…...