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

代码江湖:Python 中的进程与线程

大家好,我是阔升。今天,咱们来聊聊 Python 中的两个"老熟人"——进程和线程。这两个概念可以说是 Python 多任务编程中的"双子星",既相似又不同,让不少小伙伴们头疼不已。不过别担心,今天我们就来一起剖析一下它们的前世今生,看看怎么在实际编程中驾驭这两个"小妖精"。

进程 vs 线程:一个江湖,两种武功

进程:独立的武林高手

想象一下,每个进程就像是一位独立的武林高手,有自己的独门武功(代码)和内力(资源)。他们各自占山为王,互不干扰。在 Python 中,我们可以用 multiprocessing 模块来创建和管理这些"高手"。

from multiprocessing import Processdef kung_fu_master(name):print(f"{name} 正在施展绝世武功!")if __name__ == "__main__":p1 = Process(target=kung_fu_master, args=("张三丰",))p2 = Process(target=kung_fu_master, args=("独孤求败",))p1.start()p2.start()p1.join()p2.join()

运行这段代码,你会看到两位武林高手同时大展神威。这就是多进程的魅力所在——它们能够真正并行执行任务。

线程:同门师兄弟

相比之下,线程就像是同一个门派的师兄弟。他们共享功力(内存资源),但各自有自己的绝技(执行不同的代码片段)。在 Python 中,我们用 threading 模块来处理这些"师兄弟"。

import threadingdef shaolin_technique(technique):print(f"少林弟子正在使用 {technique}!")t1 = threading.Thread(target=shaolin_technique, args=("罗汉拳",))
t2 = threading.Thread(target=shaolin_technique, args=("金钟罩",))t1.start()
t2.start()t1.join()
t2.join()

这段代码展示了两个少林弟子在同时施展不同的武功。线程之间切换迅速,看起来就像是并行执行,但实际上它们是在共享 CPU 时间。

何时使用进程,何时选择线程?

选择使用进程还是线程,就像在武侠世界中选择独行侠还是组建门派。这里有几个考虑因素:

  1. 任务的独立性:如果任务之间相互独立,不需要频繁共享数据,那么使用多进程可能更合适。

  2. 资源消耗:进程比线程更"重",创建和管理的开销更大。如果你的应用需要创建大量的并发单元,线程可能是更好的选择。

  3. 全局解释器锁(GIL):Python 的 GIL 限制了多线程在 CPU 密集型任务上的表现。对于此类任务,多进程可能更有优势。

  4. 编程复杂度:多线程编程通常比多进程编程更容易上手,但也更容易出现难以调试的问题(比如死锁)。

实战案例:武林大会

让我们来一个实际的例子,模拟一次武林大会,看看如何巧妙运用进程和线程:

import multiprocessing as mp  # 导入多进程模块
import threading  # 导入多线程模块
import time  # 导入时间模块,用于模拟表演时间def martial_art_showcase(art):"""模拟单个武功的表演过程:param art: 武功名称"""print(f"{art} 表演开始")time.sleep(2)  # 模拟表演时间,暂停 2 秒print(f"{art} 表演结束")def manage_performances(arts):"""管理一组武功的表演,每个武功使用一个线程:param arts: 武功列表"""threads = []for art in arts:# 为每个武功创建一个线程t = threading.Thread(target=martial_art_showcase, args=(art,))threads.append(t)t.start()  # 开始线程# 等待所有线程完成for t in threads:t.join()if __name__ == "__main__":# 定义武林大会的节目单,每个子列表代表一个比武场地的表演martial_arts = [["太极拳""形意拳""八卦掌"]["少林功夫""武当剑法""峨眉刺绣"]["蛇形刁手""醉拳""猴拳"]]processes = []for arts in martial_arts:# 为每个比武场地创建一个进程p = mp.Process(target=manage_performances, args=(arts,))processes.append(p)p.start()  # 启动进程# 等待所有进程完成for p in processes:p.join()print("武林大会圆满结束!")# 解释:
# 1. 我们使用多进程来模拟多个比武场地同时进行表演。
# 2. 在每个进程(场地)内,我们使用多线程来模拟多个武功同时表演。
# 3. 这种结构允许我们充分利用多核处理器(多进程),同时在每个进程内高效地管理多个任务(多线程)。
# 4. 使用进程可以绕过 Python 的全局解释器锁(GIL),实现真正的并行。
# 5. 使用线程可以在单个进程内实现轻量级的并发,适合 I/O 密集型任务(如我们的模拟表演)。

在这个例子中,我们用进程来模拟不同的比武场地,每个场地内部用线程来管理不同武功的表演。这样,我们就巧妙地结合了进程的并行能力和线程的轻量级特性。

通过这个实战案例,我们可以看到:

  1. 进程用于实现真正的并行,适合 CPU 密集型任务或需要隔离的场景。
  2. 线程用于实现轻量级的并发,适合 I/O 密集型任务或共享内存的场景。
  3. 合理组合进程和线程可以充分利用系统资源,提高程序的整体性能。

这个武林大会的例子展示了如何在实际应用中灵活运用进程和线程,相信大家现在对这两个概念有了更直观的理解。

最后的话

进程和线程就像是 Python 多任务编程中的阴阳两面。掌握它们的特性和使用方法,就像武林高手掌握了内外兼修的绝世武功。在实际开发中,要根据具体情况灵活选择,有时候甚至可以两者结合,才能发挥出最强大的威力。

记住,无论是进程还是线程,都是为了让我们的程序更高效、更强大。所以,小伙伴们,练好这门功夫,让你的 Python 代码所向披靡,无人能挡!

阔升在这里祝大家编程愉快,功力日进。我们下期再见!

相关文章:

代码江湖:Python 中的进程与线程

大家好,我是阔升。今天,咱们来聊聊 Python 中的两个"老熟人"——进程和线程。这两个概念可以说是 Python 多任务编程中的"双子星",既相似又不同,让不少小伙伴们头疼不已。不过别担心,今天我们就来…...

根据H在有限域GF(2^m)上求解生成矩阵G

原理 有时间再补充。 注1:使用高斯消去法。如果Py不为单位阵,则说明进行了列置换,此时G不是系统形式。 注2:校验矩阵H必须是行满秩才存在对应的生成矩阵G,且生成矩阵G通常不唯一。 matlab实现:只做列置…...

Django 实现子模版继承父模板

背景 Django的占位符,如果不继承父模板的内容,会被子模版所覆盖,有些业务场景子模版也需要使用到父模板中的内容 可以使用Django自带的标签{% block super %}来实现此效果 base.html 最基础html,相当于第一层html,bl…...

数据安全治理:从库级权限申请到表级权限申请

背景 随着数据安全意识的提高,企业越来越重视数据治理和权限管理。传统数仓大多对库级别进行读写授权,仅对人工标记的敏感库进行表级别授权,但由于敏感等级是由人为标记,错误率较高,故期望将权限申请流程细化到表级申…...

vue3源码(六)渲染原理-runtime-core

1.依赖关系 runtime-dom 依赖于runtime-core,runtime-core 依赖于reactivity和sharedruntime-core提供跨平台的渲染方法createRenderer,用户可以自己传递节点渲染的渲染方法renderOptions,本身不关心用户使用什么APIruntime-dom提供了为浏览器而生的渲染…...

python拆分Excel数据,自动发邮箱

import pandas as pd import poplib import email from email.header import decode_header from email.parser import Parser df = pd.read_excel("年假明细表.xlsx") depts = df["部门"].unique() for dept in depts: department_df = df[df[&q…...

2024年福州延安中学夏季拿云杯拔尖创新人才素养测试(小高组)

1、选择题 那么,mn的值是( ) A、1243 B、1343 C、4029 D、4049 2、填空题 一副扑克牌共54张,其中1到13点各有 4张,每个数字黑色红色各两张,还有两张王牌,至少要取出( )…...

ES6 之 Promise 构造函数知识点总结 (四)

Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了 Promise 对象。 Promise 对象有以下两个特点。 对象的状态不受…...

KIVY 3D Rotating Monkey Head¶

7 Python Kivy Projects (With Full Tutorials) – Pythonista Planet KIVY 3D Rotating Monkey Head kivy 3D 旋转猴子头How to display rotating monkey example in a given layout. Issue #6688 kivy/kivy GitHub 3d 模型下载链接 P99 - Download Free 3D model by …...

测试几个 ocr 对日语的识别情况

测试几个 ocr 对日语的识别情况 1. EasyOCR2. PaddleOCR3. Deepdoc(识别pdf中图片)4. Deepdoc(识别pdf中文字)5. Nvidia neva-22b6. Claude 3.5 sonnet 识别图片中的文字7. Claude 3.5 sonnet 识别 pdf 中表格8. OpenAI gpt-4o 识…...

华为机考前准备工作

很多同学在刷完真题后,就直接去考试了,会发现不是卡在了题目的难度上,而是卡在了代码数据的如何输入上。为了避免各位有志之士忽略小细节而导致的前功尽弃,博主特意总结了华为机考试题数据输入的几种情况及其源代码,仅…...

偏差、方差(训练误差,验证误差)

目录 一、偏差、方差:二、正则化参数λ对偏差、方差的影响:三、训练集规模对偏差、方差的影响:四、模型复杂度对偏差、方差的影响:五、方差、偏差如何帮助训练:1.高偏差解决方法:2.高方差解决方法&#xff…...

Retrofit框架源码深度剖析【Android热门框架分析第二弹】

Android热门框架解析,你确定不来看看吗? OkHttp框架源码深度剖析【Android热门框架分析第一弹】 Retrofit框架源码深度剖析【Android热门框架分析第二弹】 什么是Retrofit? 准确来说,Retrofit 是一个 RESTful 的 HTTP 网络请求…...

C++Windows环境搭建(CLion)

文章目录 CLion下载安装CLion下载CLion安装新建项目新建一个文件基础设置字体设置clion中单工程多main函数设置 参考 CLion下载安装 CLion下载 打开网址:https://www.jetbrains.com/clion/download/ 点击Download进行下载。 CLion安装 双击下载好的安装包&…...

【区块链 + 智慧政务】省级一体化区块链平台 | FISCO BCOS应用案例

在加强数字政府建设的大背景下,科大讯飞广泛应用数字技术于政府管理服务,推动政府数字化、智能化运行。同时, 统筹推进业务、数据和技术的融合,提升跨地域、跨层级、跨部门和跨业务的协同管理和服务水平。 当前政务信息化建设中&…...

局域网远程共享桌面如何实现

在局域网内实现远程共享桌面,可以通过以下几种方法: 一、使用Windows自带的远程桌面功能: 首先,在需要被控制的电脑上右键点击“此电脑”,选择“属性”。 进入计算机属性界面后,点击“高级系统设置”&am…...

Ubuntu固定虚拟机的ip地址

1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安装时报错W: Target CNF (multiverse/cnf/Commands-all) is configured multiple times in /etc/apt/sources.list:10, 检查 /etc/apt/sources.list…...

python破解密码·筛查和选择

破解密码时可能遇到的几种情况 ① 已知密码字符,破排序 ② 已知密码位数,破字符 ③ 已知密码类型,破字位 ④ 已知部分密码,破未知 ⑤ 啥都不知道,盲破,玩完 ⑥ 已知位数、字符、类型、部分密码中的几个&am…...

【将应用程序注册为系统服务】

在 Linux 系统中,将应用程序注册为系统服务可以使其在系统启动时自动运行,并且可以通过 systemctl 命令进行管理。/etc/systemd/system 目录是用于存放用户定义的 systemd 服务单元文件的目录。 将 Logstash 注册为系统服务 假设你已经安装了 Logstash…...

从0-1搭建一个web项目(路由目录分析)详解

本章分析vue路由目录文件详解 ObJack-Admin一款基于 Vue3.3、TypeScript、Vite3、Pinia、Element-Plus 开源的后台管理框架。在一定程度上节省您的开发效率。另外本项目还封装了一些常用组件、hooks、指令、动态路由、按钮级别权限控制等功能。感兴趣的小伙伴可以访问源码点个赞…...

RestClient

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

CTF show Web 红包题第六弹

提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 ​ 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...

Qt/C++开发监控GB28181系统/取流协议/同时支持udp/tcp被动/tcp主动

一、前言说明 在2011版本的gb28181协议中,拉取视频流只要求udp方式,从2016开始要求新增支持tcp被动和tcp主动两种方式,udp理论上会丢包的,所以实际使用过程可能会出现画面花屏的情况,而tcp肯定不丢包,起码…...

大数据零基础学习day1之环境准备和大数据初步理解

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

转转集团旗下首家二手多品类循环仓店“超级转转”开业

6月9日,国内领先的循环经济企业转转集团旗下首家二手多品类循环仓店“超级转转”正式开业。 转转集团创始人兼CEO黄炜、转转循环时尚发起人朱珠、转转集团COO兼红布林CEO胡伟琨、王府井集团副总裁祝捷等出席了开业剪彩仪式。 据「TMT星球」了解,“超级…...

【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分

一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计,提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合:各模块职责清晰,便于独立开发…...

「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案

在移动互联网营销竞争白热化的当下,推客小程序系统凭借其裂变传播、精准营销等特性,成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径,助力开发者打造具有市场竞争力的营销工具。​ 一、系统核心功能架构&…...

Unity中的transform.up

2025年6月8日,周日下午 在Unity中,transform.up是Transform组件的一个属性,表示游戏对象在世界空间中的“上”方向(Y轴正方向),且会随对象旋转动态变化。以下是关键点解析: 基本定义 transfor…...

Python训练营-Day26-函数专题1:函数定义与参数

题目1:计算圆的面积 任务: 编写一个名为 calculate_circle_area 的函数,该函数接收圆的半径 radius 作为参数,并返回圆的面积。圆的面积 π * radius (可以使用 math.pi 作为 π 的值)要求:函数接收一个位置参数 radi…...

篇章二 论坛系统——系统设计

目录 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 1. 数据库设计 1.1 数据库名: forum db 1.2 表的设计 1.3 编写SQL 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 通过需求分析获得概念类并结合业务实现过程中的技术需要&#x…...