Python的并发编程-3

news/2025/1/11 8:11:32/

Python的并发编程

Python作为一门被广泛应用的编程语言,在并发编程领域也有其独特的优势。随着计算机和网络技术的不断发展,现代应用程序需求的复杂性也在不断增加,对于并发编程的需求也越来越迫切。Python的并发编程机制提供了多种方式,能够满足不同场景下的需求。

本文将介绍Python中的并发编程基本概念,生成器和协程,异步函数,以及aiohttp库等相关知识点。我们将从理论和实践两个角度来深入探讨这些概念,帮助读者更好地理解Python的并发编程机制,并能够应用到实际项目中。

并发编程基本概念

首先,我们需要了解并发编程中的一些基本概念。在这里,我们介绍两个概念:同步/异步和阻塞/非阻塞。

同步/异步

同步和异步是指程序执行的方式。同步指程序按照顺序执行,即代码的执行顺序和程序的执行顺序一致;异步指程序在执行过程中可以进行其他操作,即在进行某个操作的时候,程序可以同时进行其他操作。在异步编程中,程序可以通过回调函数或者协程等方式来处理异步操作的结果。

举个例子来说明,假设我们需要从网页上抓取一些数据,同步编程中,程序会依次发起请求并等待响应,直到所有请求都完成才会继续执行下一步。而在异步编程中,程序可以同时发起多个请求,并在等待响应的过程中处理其他操作,等到响应返回后再处理结果。

阻塞/非阻塞

阻塞和非阻塞是指程序等待操作结果的方式。阻塞指程序在等待某个操作的结果时,会一直等待,直到操作完成并返回结果;非阻塞指程序在等待某个操作的结果时,可以同时执行其他操作,不会一直等待。在阻塞编程中,程序通常需要使用多线程或者多进程等方式来处理多个任务;而在非阻塞编程中,程序可以使用异步编程的方式来处理多个任务。

生成器和协程

Python中的生成器和协程是并发编程中的两个重要概念,下面我们将分别介绍。

生成器

Python中的生成器是一种特殊的函数,可以被用来生成一个值序列,而不是一次性生成所有的值。生成器的特点是可以在需要的时候生成值,而不是一次性生成所有值并保存在内存中。这样可以节省内存,并且可以在需要时按需生成值。

下面是一个生成斐波那契数列的例子:

def fib(n):a, b = 0, 1for _ in range(n):yield aa, b = b, a + bgen_obj = fib(20)
print(gen_obj)for value in gen_obj:print(value)

输出:

<generator object fib at 0x106daee40>
0
1
1
2
3
5
8
13
21
34
55
89
144
233
377
610
987
1597
2584
4181

可以看出,生成器通过yield关键字实现对数列的生成,每次迭代生成一个数,而不是一次性生成所有数,可以节省内存。

协程

协程是一种轻量级的线程,可以在同一线程内实现多个子程序的协作,从而实现并发编程。协程的实现依赖于生成器,可以通过yield关键字和send方法实现协程的调度。

下面是一个简单的协程示例:

def calc_average():total, counter = 0, 0avg_value = Nonewhile True:curr_value = yield avg_valuetotal += curr_valuecounter += 1avg_value = total / counterdef main():obj = calc_average()# 生成器预激活obj.send(None)for _ in range

异步函数

Python中的协程是基于生成器实现的,而异步函数则是Python 3.5及以上版本新增的语法特性,用于实现异步编程。异步函数可以通过asyncawait关键字来定义,其语法类似于普通函数,但是可以在函数内部使用await关键字来调用其他异步函数。

下面是一个异步函数的例子:

import asyncioasync def get_data():# 模拟异步操作await asyncio.sleep(1)return "data"async def main():data = await get_data()print(data)loop = asyncio.get_event_loop()
loop.run_until_complete(main())

在这个例子中,我们定义了一个异步函数get_data,并在其中使用了await asyncio.sleep(1)来模拟异步操作。在main函数中,我们使用await关键字来调用get_data函数,并在获取到结果后打印出来。最后,我们使用asyncio.get_event_loop()来获取事件循环对象,并使用loop.run_until_complete()方法来运行main函数。

异步函数的优点在于可以更好地利用CPU和IO资源,提升应用程序的性能和响应速度。但是在使用异步函数时需要注意,异步函数通常需要与事件循环配合使用,否则可能会出现无法预料的错误。

aiohttp库

aiohttp是Python中用于异步HTTP客户端/服务器编程的库,可以与异步函数和协程配合使用,提升网络请求的性能和响应速度。aiohttp库提供了与requests库类似的API接口,使用起来非常方便。

下面是一个使用aiohttp库的例子:

import aiohttp
import asyncioasync def fetch_page_title(url):async with aiohttp.ClientSession() as session:async with session.get(url) as response:html = await response.text()title = re.findall(r'<title>(.*?)</title>', html, re.S)[0].strip()print(title)def main():urls = ['<https://www.python.org/>','<https://www.jd.com/>','<https://www.baidu.com/>','<https://www.taobao.com/>','<https://git-scm.com/>','<https://www.sohu.com/>','<https://gitee.com/>','<https://www.amazon.com/>','<https://www.usa.gov/>','<https://www.nasa.gov/>',]objs = [fetch_page_title(url) for url in urls]loop = asyncio.get_event_loop()loop.run_until_complete(asyncio.wait(objs))loop.close()if __name__ == '__main__':main()

在这个例子中,我们定义了一个异步函数fetch_page_title,用于抓取网页的标题。通过aiohttp.ClientSession()方法创建一个ClientSession对象,并使用session.get()方法发起异步请求。在获取到响应后,我们通过await response.text()获取到HTML文本,并使用正则表达式解析出网页标题。最后,我们使用asyncio.wait()方法来并发运行多个异步函数。

可以看出,aiohttp库可以极大地简化异步网络编程的复杂性,提高开发效率和代码可读性。

总结

本文介绍了Python的并发编程机制中的基本概念,生成器和协程,异步函数,以及aiohttp库等相关知识点。并发编程对于现代应用程序的开发至关重要,Python提供了多种方式来实现并发编程,开发人员可以根据具体需求选择不同的方式来实现。同时,需要注意并发编程中的一些关键概念,如同步/异步和阻塞/非阻塞等,以确保程序的正确性和性能。


http://www.ppmy.cn/news/47184.html

相关文章

网络安全运维人员面临的痛点分析

1. 工作压力大&#xff1a;网络安全运维人员需要时刻关注系统的安全状况&#xff0c;发现并修复漏洞&#xff0c;保护系统免受攻击和数据泄露的风险。这需要他们不断学习新知识、掌握新技能&#xff0c;并且在短时间内快速响应和处理各种安全问题&#xff0c;这种高强度的工作压…

2021遥感应用组二等奖:近20年黄河流域植被动态与生态环境效应

作品介绍 1 研究目的 基于MODIS NDVI植被指数、土地利用数据和气象数据集&#xff0c;辅以趋势分析、偏相关分析、马尔科夫转移矩阵变化分析、多元回归分析等方法&#xff0c;全面分析黄河流域2001-2020年植被时空变化特征&#xff0c;并通过构建统计模型方式&#xff0c;定量…

程序员怎么写简历?怎么挖掘自己的亮点,推销自己?

今天来跟大家聊一下怎么写简历 怎么挖掘自己的亮点 怎么跟别人推销自己 那我们就先开始吧 首先我们要心态上有一个建设 就是你要相信自己 要对自己自信一点 尽量给自己多打打气 这是另外一个很大的话题 就是怎么提高自己自信心 首先就是你要真的是相信自己 就像你在卖东西的时候…

JVM常用调优参数 ——JVM篇

JVM常用性能调优参数详解 ​ 在学习完整个JVM内容后&#xff0c;其实目标不仅是学习了解整个JVM的基础知识&#xff0c;而是为了进行JVM性能调优做准备&#xff0c;所以以下的内容就是来说说JVM性能调优的知识。 一、性能调优 ​ 性能调优包含多个层次&#xff0c;比如&…

【数据结构】期中考试一把梭(通宵版上)

前言 红中(Hong_zhong) CSDN内容合伙人、2023年新星计划web安全方向导师、 吉林师范大学网安大一的一名普通学生、摸鱼拿过大挑校二、 华为MindSpore截至目前最年轻的优秀开发者、IK&N战队队长、 阿里云专家博主、华为网络安全云享专家、腾讯云自媒体分享计划博主、 划了…

推动开发者平台本土化,高通加速中国XR内容生态发展

随着VR和AR技术快速发展&#xff0c;产品不断成熟&#xff0c;体验也变得越来越优秀。据悉&#xff0c;Meta Quest系列VR头显出货量超2000万台&#xff0c;基本证明了VR开始在消费类电子产品中占据一席之地。与此同时&#xff0c;近两年AR眼镜也在逐渐升温&#xff0c;成为了创…

并发编程之五FutureTask

futureTask实现了Runnable, Future接口&#xff0c;Future接口有如下定义&#xff1a; /*** 取消任务&#xff0c;如果任务已经在执行&#xff0c;mayInterruptIfRunning为true&#xff0c;则* 向执行线程发送interrupt事件&#xff0c;否则任由任务执行完毕。* 返回值为是否取…

VMware开机自启虚拟机系统

一、前提 wmware开机自启&#xff0c;安装完毕wmware不用管&#xff0c;默认该软件以及相关服务就是开机自启准备waware虚拟机&#xff08;一般都linux&#xff0c;我用centos7&#xff0c;你随意&#xff09; 二、脚本 脚本命令如下&#xff0c;等待30秒&#xff08;给服务自启…