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

React 第五十五节 Router 中 useAsyncError的使用详解

前言 useAsyncError 是 React Router v6.4 引入的一个钩子,用于处理异步操作(如数据加载)中的错误。下面我将详细解释其用途并提供代码示例。 一、useAsyncError 用途 处理异步错误:捕获在 loader 或 action 中发生的异步错误替…...

HTML 语义化

目录 HTML 语义化HTML5 新特性HTML 语义化的好处语义化标签的使用场景最佳实践 HTML 语义化 HTML5 新特性 标准答案&#xff1a; 语义化标签&#xff1a; <header>&#xff1a;页头<nav>&#xff1a;导航<main>&#xff1a;主要内容<article>&#x…...

进程地址空间(比特课总结)

一、进程地址空间 1. 环境变量 1 &#xff09;⽤户级环境变量与系统级环境变量 全局属性&#xff1a;环境变量具有全局属性&#xff0c;会被⼦进程继承。例如当bash启动⼦进程时&#xff0c;环 境变量会⾃动传递给⼦进程。 本地变量限制&#xff1a;本地变量只在当前进程(ba…...

【JavaEE】-- HTTP

1. HTTP是什么&#xff1f; HTTP&#xff08;全称为"超文本传输协议"&#xff09;是一种应用非常广泛的应用层协议&#xff0c;HTTP是基于TCP协议的一种应用层协议。 应用层协议&#xff1a;是计算机网络协议栈中最高层的协议&#xff0c;它定义了运行在不同主机上…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

srs linux

下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935&#xff0c;SRS管理页面端口是8080&#xff0c;可…...

python爬虫:Newspaper3k 的详细使用(好用的新闻网站文章抓取和解析的Python库)

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 一、Newspaper3k 概述1.1 Newspaper3k 介绍1.2 主要功能1.3 典型应用场景1.4 安装二、基本用法2.2 提取单篇文章的内容2.2 处理多篇文档三、高级选项3.1 自定义配置3.2 分析文章情感四、实战案例4.1 构建新闻摘要聚合器…...

使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台

🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...

零基础在实践中学习网络安全-皮卡丘靶场(第九期-Unsafe Fileupload模块)(yakit方式)

本期内容并不是很难&#xff0c;相信大家会学的很愉快&#xff0c;当然对于有后端基础的朋友来说&#xff0c;本期内容更加容易了解&#xff0c;当然没有基础的也别担心&#xff0c;本期内容会详细解释有关内容 本期用到的软件&#xff1a;yakit&#xff08;因为经过之前好多期…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数&#xff08;函数作为参数、返回值&#xff09; 三、匿名函数与闭包1. 匿名函数&#xff08;Lambda函…...