Python中的并发编程

news2025/1/23 5:02:06

目录

一、引言

二、Python中的线程

1、线程的概念

2、创建线程

3、线程同步和锁

4、线程池

三、Python中的进程

1、进程的概念

2、创建进程

四、Python中的异步IO

1、异步IO的概念

2、异步IO的实现

3、异步IO的并发执行

五、总结


一、引言

并发编程是一种计算机编程模式,旨在利用多核处理器和发挥计算机系统的最大性能。在Python中,由于其解释型语言的特性,实现并发编程具有一定的挑战性。然而,Python提供了多种工具和库,使得并发编程变得相对容易。本文将深入探讨Python中的并发编程,包括线程、进程、异步IO等。

二、Python中的线程

1、线程的概念

线程是程序执行的基本单元,它包含程序执行的指令和所需的数据。在Python中,线程是轻量级的执行上下文,可以用于实现并发。

2、创建线程

在Python中,可以使用threading模块创建线程。下面是一个简单的示例:

import threading  
  
def worker():  
    print("This is a worker thread")  
  
t = threading.Thread(target=worker)  # 创建一个工作线程  
t.start()  # 启动线程

3、线程同步和锁

在多线程程序中,线程同步和锁是两个非常重要的概念。Python中的threading模块提供了多种同步原语,如锁(Lock)、条件(Condition)、信号量(Semaphore)等。下面是一个使用锁的示例:

import threading  
  
lock = threading.Lock()  # 创建一个锁对象  
  
def worker():  
    with lock:  # 使用锁对象上下文管理器来同步代码块  
        print("This is a worker thread")

4、线程池

在Python中,可以使用concurrent.futures模块创建线程池。下面是一个使用线程池的示例:

from concurrent.futures import ThreadPoolExecutor  
  
def worker():  
    print("This is a worker thread")  
  
with ThreadPoolExecutor(max_workers=5) as executor:  # 创建一个包含5个工作线程的线程池  
    for i in range(10):  # 将10个任务提交给线程池执行  
        executor.submit(worker)  # 异步执行worker函数

三、Python中的进程

1、进程的概念

进程是计算机中的程序关于某个数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位。在Python中,进程可以用于实现并发执行。每个进程都有自己的内存空间和系统资源。

2、创建进程

在Python中,可以使用multiprocessing模块创建进程。下面是一个简单的示例:

import multiprocessing  
  
def worker():  
    print("This is a worker process")  
  
p = multiprocessing.Process(target=worker)  # 创建一个工作进程  
p.start()  # 启动进程

四、Python中的异步IO

1、异步IO的概念

异步IO是一种编程模型,用于处理长时间运行的操作,如网络请求或文件I/O,而不会阻塞主线程。在Python中,异步IO通常使用asyncio模块实现。

2、异步IO的实现

在Python中,可以使用async和await关键字定义异步函数和异步代码块。下面是一个使用异步IO的示例:

import asyncio  
  
async def worker():  
    print("This is a worker coroutine")  
    await asyncio.sleep(1)  # 模拟一个耗时的操作  
  
async def main():  
    print("Starting main coroutine")  
    await worker()  # 异步执行worker函数  
    print("Finishing main coroutine")  
  
asyncio.run(main())  # 运行main函数,并等待其完成

在上面的示例中,worker函数是一个异步函数,它使用await关键字等待一个耗时的操作。main函数是另一个异步函数,它使用await关键字等待worker函数的完成。最后,使用asyncio.run()函数运行main函数。

3、异步IO的并发执行

在Python中,可以使用asyncio.gather()函数并发执行多个异步操作。下面是一个使用asyncio.gather()函数的示例:

import asyncio  
  
async def worker(n):  
    print(f"Worker {n} is running")  
    await asyncio.sleep(1)  # 模拟一个耗时的操作  
    print(f"Worker {n} is done")  
  
async def main():  
    workers = [worker(i) for i in range(5)]  # 创建5个工作协程  
    await asyncio.gather(*workers)  # 并发执行这5个工作协程  
  
asyncio.run(main())  # 运行main函数,并等待其完成

在上面的示例中,worker函数是一个异步函数,它模拟了一个耗时的操作。main函数创建了5个工作协程,并使用asyncio.gather()函数并发执行它们。

五、总结

Python中的并发编程提供了多种工具和库来处理多线程和多进程编程。线程是轻量级的执行上下文,适用于I/O密集型任务。进程是独立的程序实例,适用于CPU密集型任务。异步IO是一种非阻塞的编程模型,适用于处理长时间运行的操作。在实际应用中,可以根据不同的需求选择合适的并发模型来提高程序的性能和响应能力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1279637.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LLM来模拟世界大战,会发生什么?

深度学习自然语言处理 原创作者:Winnie 战争与和平一直是塑造人类历史的重要元素。最近的一项研究聚焦于用LLMs模拟国际冲突,特别是第一次世界大战、第二次世界大战以及中国古代的战国时期。通过这些历史事件的详细模拟,研究团队探索了国际关…

「Verilog学习笔记」自动贩售机2

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点,刷题网站用的是牛客网 自动贩售机中可能存在的几种金额:0,0.5,1,1.5,2,2.5,3。然后直接将其作为状态机的几种状…

HTML_web扩展标签

1.表格标签 2.增强表头表现 4.表格属性(实际不常用) 结构标签: 合并单元格: 更多请查看主页

爬虫-xpath篇

1.xpath的基础语法 表达式描述nodename选中该元素/从根节点选取、或者是元素和元素间的过渡//从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置.选取当前节点…选取当前节点的父节点选取属性text()选取文本 举例: 路径表达式结果html选择html元…

Nacos源码解读04——服务发现

SpringBoot自动注入 项目启动的时候会通过自动注入的机制将 NacosDiscoveryClientConfiguration注入 当注入NacosDiscoveryClientConfiguration的时候会将DiscoveryClient一起注入Bean DiscoveryClient实现了SpringCloud的DiscoveryClient接口,重点是getInstances和…

ROS集成开发环境的搭建

目录 一、安装终端 二、安装VScode 1、安装 2、vscode 集成 ROS 插件 三、launch文件示例 实现 运行 launch 文件 一、安装终端 sudo apt install terminatorTerminator 常用快捷键 AltUp //移动到上面的终端 AltDown …

基于remix+metamask+ganache的智能合约部署调用

在我们部署合约时为了让它更接近真实区块链去中心化体验,我们需要调用小狐狸(Metamask)来进行真实交易,而metamask里没有内置虚拟测试币,我们需要进行调用Ganache来添加带有虚拟测试币的账号。以上就是三者的关系&…

量子光学的进步:光子学的“下一件小事”

量子光学是量子力学和光学交叉领域中发展迅速的一门学科,探索光的基本特性及其与物质在量子水平上的相互作用。通过利用光的独特特性,量子光学为通信、计算、密码学和传感等各个学科的变革性进步铺平了道路。 如今,量子光学领域的研究人员和工…

YITH Request a Quote Premium商城请求报价插件

点击访问原文 YITH Request a Quote Premium商城请求报价插件 - 易服客工作室 YITH Request a Quote Premium商城请求报价插件是一款非常强大的工具,专为希望为其尊贵客户提供定制定价选项的企业量身定制。这个特殊的插件使客户能够认真提交包含特定产品或服务的细…

Python---格式化输出与%百分号----涉及转义符 \ 反斜杠的使用

相关链接Python--格式化输出中的转义符号----\t 制表符(空格的)和\n(换行的)_唯元素的博客-CSDN博客 Python---字符串(用单、双引号、 三单/双引号定义。反斜杠 \ 转义,单在双内/双在单内 )-CS…

手写VUE后台管理系统7 - 整合Less样式

整合LESS 安装使用 Less(Leaner Style Sheets),是一门向后兼容的 CSS 扩展语言。 Less 官网:https://less.bootcss.com/ 安装 yarn add less安装完成就可以直接使用了 使用 以文件形式定义全局样式 在 assets 目录下创建 less …

【Element-ui】InputNumber 计数器与Select 选择器

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、InputNumber 计数器1.1 基础用法:1.2 禁用状态1.3 步数1.4 严格步数1.5 精度1.6 尺寸1.7 按钮位置1.8 Events1.9 Methods 二、Select 选择器2.1…

超大规模集成电路设计----学习框架(一)

本文仅供学习,不作任何商业用途,严禁转载。绝大部分资料来自----数字集成电路——电路、系统与设计(第二版)及中国科学院段成华教授PPT 超大规模集成电路设计----学习框架(一) 这门课在学什么?这门课该怎么学&#xf…

Java LeetCode篇-深入了解关于栈的经典解法(栈实现:中缀表达式转后缀)

🔥博客主页: 【小扳_-CSDN博客】 ❤感谢大家点赞👍收藏⭐评论✍ 文章目录 1.0 中缀表达式转后缀说明 1.1 实现中缀表达式转后缀思路 2.0 逆波兰表达式求值 2.1 实现逆波兰表达式求值思路 3.0 有效的括号 3.1 实现有效的括号思路 4.0 栈的压…

魔法时代:人工智能如何重塑我们的日常生活

现在的我们正在目睹一个新时代的到来——人工智能(AI)的时代。这个时代由算法驱动,由数据精炼,由机器学习引领,正逐渐成为我们生活中不可或缺的一部分。人工智能像一位魔法师,以其独特的能力,从根本上改变了我们的生活…

力扣题:字符的统计-12.2

力扣题-12.2 [力扣刷题攻略] Re:从零开始的力扣刷题生活 力扣题1:423. 从英文中重建数字 解题思想:有的单词通过一个字母就可以确定,依次确定即可 class Solution(object):def originalDigits(self, s):""":typ…

Hdoop学习笔记(HDP)-Part.14 安装YARN+MR

目录 Part.01 关于HDP Part.02 核心组件原理 Part.03 资源规划 Part.04 基础环境配置 Part.05 Yum源配置 Part.06 安装OracleJDK Part.07 安装MySQL Part.08 部署Ambari集群 Part.09 安装OpenLDAP Part.10 创建集群 Part.11 安装Kerberos Part.12 安装HDFS Part.13 安装Ranger …

可用的镜像 yum 源

目录 ftp.sjtu.edu.cn 镜像 yum 源centos 的镜像 yum 源 mirrors.sohu.comcentos 的镜像 yum 源 mirrors.163.comcentos 的镜像 yum 源 ftp.sjtu.edu.cn 镜像 yum 源 镜像 yum 源地址 : http://ftp.sjtu.edu.cn/centos/ centos 的镜像 yum 源 http://ftp.sjtu.edu…

git如何关联克隆远程仓库

一、添加远程仓库 之前我们仅仅是在本地创建了一个Git本地仓库,这里我们再在GitHub创建一个Git远程仓库,并且让这两个仓库进行远程同步,这样,GitHub上的仓库既可以作为备份,又可以让其他人通过该仓库来协作开发。 1.…

面试--各种场景问题总结

1.在开发过程中,你是如何保证机票系统的正常运行的? 用户、测试、监控和日志、安全措施、数据备份、系统设计、需求分析 2.在机票系统开发过程中,你最有成就的事情,为什么? 用户体验感、高可用和稳定性、客户满意度、系…