news 2026/7/2 8:51:37

你的代码为何高并发就卡死?进程、线程、协程选对的秘密!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
你的代码为何高并发就卡死?进程、线程、协程选对的秘密!

在进入正题之前,我们先说一下并行和并发的区别:

(感觉是同时): 同一刻快速交替执行多个任务

(真的同时): 同一刻真正同时执行多个任务

一,进程

进程有三大步骤,分别是:《1》导包: importmultiprocessing

《2》创建进程: 进程对象名 = multiprocessing.Process(target=任务名)

《3》启动进程:进程对象名.start()

创建进程中的几个参数解释:《1》args: 以元组的形式传递参数, 注意: 如果只有1个参数加逗号

《2》kwargs: 以字典形式传递参数, 注意: 字典的key必须和任务中形参名一致

《3》name: 默认进程名称是Process-1,Process-2...,也可以直接指定

《4》target: 指定携带任务的函数名, 注意: 没有括号

二,线程

线程有三大步骤,分别是:《1》导包: importthreading

《2》创建线程: 进程对象名 = multiprocessing.Thread(target=任务名)

《3》启动线程:线程对象名.start()

创建线程中的几个参数解释:《1》args: 以元组的形式传递参数, 注意: 如果只有1个参数加逗号

《2》kwargs: 以字典形式传递参数, 注意: 字典的key必须和任务中形参名一致

《3》name: 默认线程名称是Thread-1,Thread-2...,也可以直接指定

《4》target: 指定携带任务的函数名, 注意: 没有括号

三,进程和线程

区别:

《1》进程之间不共享全局变量

《2》线程之间共享全局变量

《3》 创建进程的资源开销要比创建线程的资源开销要大

《4》进程是操作系统资源分配的最小单位,线程是CPU调度的最小单位

关系:

《1》线程是依附在进程里面的,没有进程就没有线程。

《2》 一个进程默认提供一条线程,进程可以创建多个线程。

四.协程

python中的协程是从生成器发展来的

协程的三要素:async def 定义函数

await 指定等待处

asyncio.run()

注:最后提示一下,我们python中的生成器推导式:(i for i in range(x))

生成器函数就是在函数内使用了yield关键字

综上,我们如何选择进程线程协程呢?如果是CPU密集型主要是数学计算我们使用进程;如果是简单的后台任务,简单易用我们用线程;如果是I/O密集型,主要是网络请求或者文件读写,我们用协程。一句话总结,进程真正同时做事,线程看起来同时做事,协程单线程内切换做事。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/2 2:26:08

Flutter Provider 状态管理深度解析与开源鸿蒙 ArkUI 状态管理对比

文章目录Flutter Provider 状态管理深度解析与开源鸿蒙 ArkUI 状态管理对比引言一、Flutter Provider 核心原理1.1 什么是 Provider1.2 Provider 核心组件1.3 Provider 工作流程二、Flutter Provider 实战教程2.1 环境准备2.2 案例:实现一个计数器应用步骤1&#xf…

作者头像 李华
网站建设 2026/7/2 3:36:48

Vue.js 前端框架开发知识点总结

前言Vue.js 作为目前最流行的前端框架之一,以其简洁的 API、灵活的组件化和优秀的性能获得了广大开发者的青睐。本文将系统总结 Vue.js 的核心知识点,帮助开发者更好地掌握这一框架。一、Vue.js 核心概念1.1 响应式原理Vue.js 的响应式系统是其核心特性&…

作者头像 李华
网站建设 2026/7/2 1:36:31

行测教程资源合集

归墟行测 文件大小: 9.9GB内容特色: 9.9GB行测全套题库视频精讲,夸克秒下适用人群: 国考、省考、事业单位备考者核心价值: 刷题模考解析一站式,提分快下载链接: https://pan.quark.cn/s/201aaf99d2e4 半月谈付费行测申论资料 文件大小: 57.6GB内容特色…

作者头像 李华