当前位置: 首页 > 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是⼀个单独集成化的程序⽽不是⼀些分散程序的集合&#…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销,平衡网络负载,延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...

React Native 开发环境搭建(全平台详解)

React Native 开发环境搭建(全平台详解) 在开始使用 React Native 开发移动应用之前,正确设置开发环境是至关重要的一步。本文将为你提供一份全面的指南,涵盖 macOS 和 Windows 平台的配置步骤,如何在 Android 和 iOS…...

《从零掌握MIPI CSI-2: 协议精解与FPGA摄像头开发实战》-- CSI-2 协议详细解析 (一)

CSI-2 协议详细解析 (一) 1. CSI-2层定义(CSI-2 Layer Definitions) 分层结构 :CSI-2协议分为6层: 物理层(PHY Layer) : 定义电气特性、时钟机制和传输介质(导线&#…...

[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?

论文网址:pdf 英文是纯手打的!论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误,若有发现欢迎评论指正!文章偏向于笔记,谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...

Swagger和OpenApi的前世今生

Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章,二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑: 🔄 一、起源与初创期:Swagger的诞生(2010-2014) 核心…...

学习STC51单片机32(芯片为STC89C52RCRC)OLED显示屏2

每日一言 今天的每一份坚持,都是在为未来积攒底气。 案例:OLED显示一个A 这边观察到一个点,怎么雪花了就是都是乱七八糟的占满了屏幕。。 解释 : 如果代码里信号切换太快(比如 SDA 刚变,SCL 立刻变&#…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)

Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败,具体原因是客户端发送了密码认证请求,但Redis服务器未设置密码 1.为Redis设置密码(匹配客户端配置) 步骤: 1).修…...

laravel8+vue3.0+element-plus搭建方法

创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...

使用Matplotlib创建炫酷的3D散点图:数据可视化的新维度

文章目录 基础实现代码代码解析进阶技巧1. 自定义点的大小和颜色2. 添加图例和样式美化3. 真实数据应用示例实用技巧与注意事项完整示例(带样式)应用场景在数据科学和可视化领域,三维图形能为我们提供更丰富的数据洞察。本文将手把手教你如何使用Python的Matplotlib库创建引…...

scikit-learn机器学习

# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...