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

php中进程、线程、协程详细讲解

目录

一、什么是进程、线程、协程

1、什么是进程(Process):

2 、什么是线程(Thread):

 3、什么是协程(Coroutine):

二、 进程、线程、协程的关系

1、进程与线程关系

2、进程与协程关系

 3、协程关系与线程关系

 三、进程、线程、协程在php中应用

1、在php中进程应用

  2、在php中线程应用

3、在php中线程应用


一、什么是进程、线程、协程

1、什么是进程(Process):

进程是操作系统分配资源的基本单位,每个进程都有自己的地址空间、数据栈、代码段和打开的文件等系统资源。进程之间相互独立,通过多进程可以并发执行多个任务。进程拥有独立的内存空间,进程间的通信需要通过特殊的IPC(Inter-Process Communication)机制来实现。由于进程切换的开销较大,因此多进程的并发性能相对较低。

2 、什么是线程(Thread):

线程是进程内的执行单元,一个进程可以有多个线程。线程共享进程的资源,包括内存空间、文件句柄等。不同的线程可以通过共享内存进行通信,但是需要注意线程间的同步和互斥。由于线程共享进程的地址空间,线程切换的开销较小,因此多线程的并发性能相对较高。然而,由于线程间的共享资源,需要考虑线程安全的问题。

 3、什么是协程(Coroutine):

协程是一种轻量级的线程,也被称为用户态线程。协程由用户程序控制,并非由操作系统调度。协程的特点是可以在代码中显式地指定在何处进行切换,并且切换开销较小。协程可以在同一线程内多个任务之间切换执行,也可以通过多线程调度不同协程。协程广泛应用于异步编程,可以提高并发性能和资源的利用率。

二、 进程、线程、协程的关系

1、进程与线程关系

进程和线程是计算机系统中的两个重要概念,它们之间存在密切的关系。 进程是计算机中正在运行的程序的实例,它拥有独立的内存空间和系统资源。每个进程都是独立运行的,有自己的代码、数据和执行环境。进程之间不能直接共享数据,如果需要进程间通信,需要使用特定的机制,例如管道、消息队列等。 线程是进程的执行单位,一个进程可以拥有多个线程。线程是进程中的一个轻量级运行单位,它与同一进程中的其他线程共享内存、文件和其他系统资源。不同线程之间可以通过共享内存来直接交流数据,这使得线程间的通信更加高效。 进程与线程之间有以下关系:

  1. 进程中至少包含一个线程,即主线程。主线程负责执行程序的主要逻辑。
  2. 多个线程可以在同一个进程中并发执行,共享进程的资源。
  3. 同一进程中的线程之间可以通过共享内存进行数据交换,而不需要使用额外的进程间通信机制。
  4. 进程是操作系统资源分配的最小单位线程是调度的最小单位
  5. 一个进程崩溃通常不会影响其他进程,但一个线程崩溃可能会导致整个进程崩溃。 总结来说,进程是资源分配的最小单位,线程是调度的最小单位。一个进程可以包含多个线程,线程之间共享进程的资源,通过共享内存来进行数据交换。进程和线程的关系是一种包含和被包含的关系。
2、进程与协程关系
进程协程
定义和特点操作系统进行资源分配和调度的基本单位,每个进程都拥有独立的内存空间和系统资源,进程之间是相互独立的一种用户态的轻量级线程,它可以在同一个线程中实现多个协程的切换和调度,每个协程都有自己的运行栈,但共享同一个线程的上下文和资源
调度方式由操作系统进行管理和调度的,操作系统根据进程的优先级、进程状态等因素决定进程的执行顺序用户程序自己控制的,程序员可以通过特定的代码来进行协程的切换和调度,不依赖于操作系统的调度算法
切换开销需要保存和恢复进程的上下文,包括寄存器状态、内存映射、文件描述符等,因此进程切换的开销相对较大只需保存和恢复协程的上下文,开销相对较小。协程的切换是由用户程序自己控制的,并且切换可以在恰当的时机进行,避免了不必要的上下文切换
并发性并发执行的,每个进程有自己的执行环境和资源同一个线程中切换执行,实现了并发执行的效果,但实际上并不是真正的并行执行

总的来说,进程和协程都是用于实现并发和并行的机制,但进程更多地依赖于操作系统的调度和资源管理,而协程则由程序员自行控制。进程之间是相互独立的,而协程之间可以在同一个线程中共享资源并进行高效的切换

 3、协程关系与线程关系

协程和线程都是实现并发和并行的机制,但它们有着不同的特点和关系。 协程与线程关系:

  1. 执行方式:线程在操作系统内核的调度下执行,进程切换由操作系统负责;而协程则由用户程序自己控制切换,通常在同一线程中实现。
  2. 切换开销:线程切换需要保存和恢复现场,有较大的开销协程切换只需保存和恢复协程的上下文,开销较小
  3. 并发性:线程是操作系统分配资源和调度的基本单位线程之间相互独立,可以并发执行;而协程通过在同一线程中切换执行,实现协作式并发,协程之间可以共享线程的资源。 协程与线程的区别:
  4. 内存和资源:线程是操作系统分配的执行流,具有独立的内存空间和系统资源;而协程是用户态的执行流,共享线程的内存和资源
  5. 控制权:线程由操作系统调度器控制协程由程序员手动控制。
  6. 切换方式:线程切换是由调度器决定的,通常是抢占式切换;协程切换是通过程序显式的切换,通常是协作式切换
  7. 并发模型:线程采用多对多的模型,多个线程并行执行;协程采用多对一的模型,多个协程在同一个线程中切换执行。
  8. 线程之间通信:线程之间可以使用共享内存、消息队列、锁等机制来进行通信;协程之间可以通过共享数据和消息传递等方式进行通信。 总结来说,协程和线程都是实现并发的方法,但协程更加轻量级和灵活,适合在单线程中实现协作式并发。线程是操作系统分配的资源,可以并发执行,并且线程之间相互独立。而协程是程序员自行控制的执行流,共享线程的资源,通过手动切换来实现并发。

 三、进程、线程、协程在php中应用

1、在php中进程应用

进程是操作系统中负责程序执行的基本单位。在PHP中,可以使用pcntl_fork()函数创建子进程,每个进程都有自己的独立的内存空间和执行上下文。通过使用进程,可以在多个进程中同时执行不同的任务

  2、在php中线程应用

线程是进程的一部分,是一个轻量级的执行单元。在PHP中,可以使用pthreads扩展来实现多线程。线程可以共享同一个进程的内存空间,使得多个线程可以同时执行不同的任务。需要注意的是,由于PHP的解释执行模式,PHP的多线程并发效果并不是特别好。

3、在php中线程应用

协程是一种用户态的轻量级线程,由用户自行控制。在PHP中,可以使用Swoole扩展来实现协程。使用协程可以避免进程或线程上下文切换的开销,提高并发处理能力。协程在执行过程中可以主动挂起和恢复,可以实现非阻塞的并发处理

相关文章:

php中进程、线程、协程详细讲解

目录 一、什么是进程、线程、协程 1、什么是进程(Process): 2 、什么是线程(Thread): 3、什么是协程(Coroutine): 二、 进程、线程、协程的关系 1、进程与线程关系 …...

无线通信中SINR的含义

在无线通信中,SINR代表"Signal-to-Interference-plus-Noise Ratio",即信号与干扰加噪声比。这是一个重要的性能度量,用于评估和描述接收信号的质量,以及在无线通信系统中的通信性能。 SINR考虑了以下三个关键因素&…...

pnp单目相机标定测距

参考:opencv 单目相机pnp测距(Cpp)-CSDN博客...

Java反射获取内部类方法

Java反射获取内部类方法 结论一、案例准备二、测试方法:使用反射获取类的成员内部类和方法具体操作具体操作(使用getDeclaredClasses) 结论 Java 通过反射可以获得内部类,包括内部类属性信息和方法。 一、案例准备 创建了一个类…...

发挥服务器的无限潜能:创意项目、在线社区和更多

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 ✨特色专栏&#xff1a…...

华为OD 绘图机器(100分)【java】A卷+B卷

华为OD统一考试A卷+B卷 新题库说明 你收到的链接上面会标注A卷还是B卷。目前大部分收到的都是B卷。 B卷对应20022部分考题以及新出的题目,A卷对应的是新出的题目。 我将持续更新最新题目 获取更多免费题目可前往夸克网盘下载,请点击以下链接进入: 我用夸克网盘分享了「华为O…...

文件上传接口

以下是一个简单的Java文件上传接口的示例代码: import org.springframework.http.HttpStatus;import org.springframework.http.ResponseEntity;import org.springframework.web.bind.annotation.PostMapping;import org.springframework.web.bind.annotation.Requ…...

基于矢量控制策略的异步电机调速系统设计

摘 要 由于国内人民生活水平的提高,科技不断地进步,控制不断地完善,从而促使矢量控制技术在电气传动系统领域占据主导权,也使得交流异步电机调速控制系统被广泛应用。在交流异步电机调速系统设计领域中,矢量控制成为目…...

Ubuntu下载工具ip addr、ifconfig、ping、make

Ubuntu下载工具ip addr、ifconfig、ping、make ping 在 Ubuntu 上获取网络工具包通常是通过安装相关软件包的方式来完成的。Ubuntu 默认包含一些常见的网络工具,但如果你需要安装其他工具,你可以使用 apt 命令或者 snap 命令进行安装。以下是一些常见的…...

【数据结构】常见复杂度习题详解 ------ 习题篇

文章目录 📋前言一. ⛳️前篇回顾二. ⛳️常见时间复杂度计算举例1️⃣实例一2️⃣实例二3️⃣实例三4️⃣实例四5️⃣实例五6️⃣实例六7️⃣实例七8️⃣实例八 三. ⛳️常见空间复杂度计算举例1️⃣实例一2️⃣实例二3️⃣实例三 四. ⛳️总结 📋前言 …...

一、vue介绍

一、介绍 vue式前端框架,是一套用于构建用户界面的渐进式框架 1、安装vue 安装node.js(配置环境变量) https://nodejs.org/en/download/ 更换镜像 npm config set registry https://registry.npm.taobao.org 查看镜像 npm config get regi…...

Linux ARMv8 异常向量表

http://blog.chinaunix.net/uid-69947851-id-5830546.html 本章接着《Linux内核启动》部分讲解,我们知道了在进入start_kernel之前,通过指令adr_l x8, vectors;msr vbar_el1, x8设置了异常向量表,那么异常向量表的结构是怎么样…...

C++基类和派生类的内存分配,多态的实现

目录 基类和派生类的内存分配基类和派生类的成员归属多态的实现 基类和派生类的内存分配 类包括成员变量(data member)和成员函数(member function)。 成员变量分为静态数据(static data)和非静态数据&…...

C/C++基础

C 二进制 问题:二进制怎么表示整数、小数、正数、负数,如何存储?加减乘除怎么运算(见文章《计算机加减乘除本质》)? 变量 c定义一个变量的时候,需要事先定义变量大小和变量类型。 //有符号…...

MySQL基础练习题

数据表介绍 --1.学生表 Student(SId,Sname,Sage,Ssex) --SId 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 --2.课程表 Course(CId,Cname,TId) --CId 课程编号,Cname 课程名称,TId 教师编号 --3.教师表 Teacher(TId,Tname) --TId 教师编号,Tname 教师姓名 --4.成绩…...

【C语言学习笔记 --- 动态内存管理】

C语言程序设计笔记---029 C语言之动态内存管理1、介绍动态内存管理2、动态内存函数的介绍2.1、malloc和free函数2.2、calloc函数2.3、realloc函数 3、动态内存管理过程中,一些常见的错误3.1、对NULL指针的解引用操作3.2、对动态内存开辟的空间的越界访问3.3、对非动…...

Nougat来了,能否成为pdf格式转换的新神器?

Nougat来了,能否成为pdf格式转换的新神器? 论文链接:https://arxiv.org/pdf/2308.13418v1.pdf 项目地址:https://github.com/facebookresearch/nougat What happened?🤨 科学知识主要存储在书籍和科学期…...

C++文件和流

到目前为止,我们已经使用了 iostream 标准库,它提供了 cin 和 cout 方法分别用于从标准输入读取流和向标准输出写入流。 本教程介绍如何从文件读取流和向文件写入流。这就需要用到 C 中另一个标准库 fstream,它定义了三个新的数据类型&#x…...

代码随想录算法训练营第23期day31|贪心算法理论基础、455.分发饼干、376. 摆动序列、53. 最大子序和

目录 一、贪心算法理论基础 二、(leetcode 455)分发饼干 三、(leetcode 376)摆动序列 四、(leetcode 53)最大子序和 一、贪心算法理论基础 1.什么是贪心 贪心的本质是选择每一阶段的局部最优&#xf…...

mdadm命令详解及实验过程

mdadm命令详解及实验过程 ⼀.概念 mdadm是multiple devices admin的简称,它是Linux下的⼀款标准的软件 RAID 管理⼯具,作者是Neil Brown ⼆.特点 mdadm能够诊断、监控和收集详细的阵列信息 mdadm是⼀个单独集成化的程序⽽不是⼀些分散程序的集合&#…...

RestClient

什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级&#xff…...

多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度​

一、引言:多云环境的技术复杂性本质​​ 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时,​​基础设施的技术债呈现指数级积累​​。网络连接、身份认证、成本管理这三大核心挑战相互嵌套:跨云网络构建数据…...

云计算——弹性云计算器(ECS)

弹性云服务器:ECS 概述 云计算重构了ICT系统,云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台,包含如下主要概念。 ECS(Elastic Cloud Server):即弹性云服务器,是云计算…...

SciencePlots——绘制论文中的图片

文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了:一行…...

shell脚本--常见案例

1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件: 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...

2.Vue编写一个app

1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...

376. Wiggle Subsequence

376. Wiggle Subsequence 代码 class Solution { public:int wiggleMaxLength(vector<int>& nums) {int n nums.size();int res 1;int prediff 0;int curdiff 0;for(int i 0;i < n-1;i){curdiff nums[i1] - nums[i];if( (prediff > 0 && curdif…...

在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module

1、为什么要修改 CONNECT 报文&#xff1f; 多租户隔离&#xff1a;自动为接入设备追加租户前缀&#xff0c;后端按 ClientID 拆分队列。零代码鉴权&#xff1a;将入站用户名替换为 OAuth Access-Token&#xff0c;后端 Broker 统一校验。灰度发布&#xff1a;根据 IP/地理位写…...

ffmpeg(四):滤镜命令

FFmpeg 的滤镜命令是用于音视频处理中的强大工具&#xff0c;可以完成剪裁、缩放、加水印、调色、合成、旋转、模糊、叠加字幕等复杂的操作。其核心语法格式一般如下&#xff1a; ffmpeg -i input.mp4 -vf "滤镜参数" output.mp4或者带音频滤镜&#xff1a; ffmpeg…...

.Net Framework 4/C# 关键字(非常用,持续更新...)

一、is 关键字 is 关键字用于检查对象是否于给定类型兼容,如果兼容将返回 true,如果不兼容则返回 false,在进行类型转换前,可以先使用 is 关键字判断对象是否与指定类型兼容,如果兼容才进行转换,这样的转换是安全的。 例如有:首先创建一个字符串对象,然后将字符串对象隐…...