关于python并发编程中的协程
作者:菜鸟小超 发布时间:2023-10-18 04:37:44
什么是协程
协程(Coroutine)是一种比线程更加轻量级的并发方式,它不需要线程上下文切换的开销,可以在单线程中实现并发。协程通常具有以下特点:
协程中的代码可以暂停执行,并且在需要的时候可以恢复执行。
多个协程可以在同一线程中并发执行,但是任意时刻只有一个协程在执行。
协程通常是基于事件循环(Event Loop)实现的,事件循环负责调度协程的执行。
协程和线程
线程和协程都是实现并发编程的方式,但它们有一些不同的特点和应用场景。
**线程是操作系统调度的基本单位,**每个线程都拥有自己的执行上下文,包括线程栈、寄存器等。线程之间的切换需要进行上下文切换,包括保存当前线程的上下文,恢复另一个线程的上下文等操作,这些操作会耗费大量的时间和资源。在多线程编程中,线程切换是非常常见的操作,原因如下:
调度。当多个线程同时执行时,操作系统需要对这些线程进行调度,根据优先级等因素决定当前应该执行哪个线程。线程切换是调度的基本操作之一,通过切换线程,操作系统可以实现多个线程的并发执行。
等待。当一个线程需要等待某个事件发生时,例如等待 IO 操作完成、等待锁释放等,线程可以主动释放 CPU,使其他线程有机会执行。在等待完成后,线程可以被重新唤醒,继续执行。
并发。线程可以实现并发执行的效果,例如一个线程处理网络请求,另一个线程处理用户交互,这样可以提高系统的响应速度和处理能力。
切换到其他线程执行。在某些情况下,线程可能会因为一些原因无法继续执行,例如线程进入了死循环或者发生了异常,这时需要切换到其他线程执行,避免系统崩溃或者出现其他问题。
线程的并发编程通常会受到多线程竞争、死锁、上下文切换等问题的限制。在 Python 中,使用多线程编程需要注意线程安全、GIL 等问题。
协程是一种轻量级的并发方式,它是在用户空间中实现的,并不依赖于操作系统的调度。协程可以在同一个线程中实现并发,不需要进行上下文切换,因此执行效率非常高。协程通常使用事件循环(Event Loop)来调度协程的执行,事件循环会在协程需要等待 IO 操作或者其他协程时,暂停当前协程的执行,执行其他协程,从而实现并发执行的效果。在 Python 中,协程通常使用 asyncio
模块来实现,支持异步 IO、网络编程、任务调度等场景。
相对于线程,协程的主要优点包括:
更加轻量级,占用的资源更少;
不需要进行上下文切换,执行效率更高;
可以使用事件循环进行调度,实现高并发的效果;
不会受到 GIL 的限制,可以更好地利用多核 CPU。
然而,协程也有一些限制,例如无法利用多核 CPU、调试困难等问题。在选择使用线程还是协程时,需要根据具体的应用场景进行选择。
协程的应用
协程可以应用于很多场景,例如:
网络编程:协程可以帮助我们实现高并发的网络应用。
异步IO:协程可以帮助我们高效地处理异步IO操作。
数据库操作:协程可以帮助我们实现高并发的数据库应用。
任务调度:协程可以帮助我们实现高效的任务调度系统。
演示Demo
下面是一个示例代码,演示了如何使用协程和 asyncio
模块来实现一个简单的任务调度:
import asyncio
async def task1():
print("Task 1")
await asyncio.sleep(1)
print("Task 1 done")
async def task2():
print("Task 2")
await asyncio.sleep(2)
print("Task 2 done")
async def task3():
print("Task 3")
await asyncio.sleep(3)
print("Task 3 done")
async def main():
await asyncio.gather(task1(), task2(), task3())
这段代码使用了 Python 的协程和 asyncio
模块,定义了三个协程函数 task1
、task2
、task3
,以及一个主协程函数 main
。每个协程函数打印自己的任务名,然后暂停一段时间。主协程函数使用 asyncio.gather
并发执行了三个协程函数,最终输出结果为:
Task 1
Task 2
Task 3
Task 1 done
Task 2 done
Task 3 done
[Finished in 3.2s]
来源:https://blog.csdn.net/weixin_41777118/article/details/130277124
猜你喜欢
- 阅读上一篇:网马解密大讲堂——网马解密中级篇(Eval篇) 一.Document.write 函数简介:在Microsoft JScript
- [摘要]了解如何充分利用SQL Server 2000的全文搜索功能。本文包含有关实现最大吞吐量和最佳性能的几点提示和技
- 在很多企业会使用闲置的 Windows 机器作为临时服务器,有时候我们想远程调用里面的程序或查看日志文件Windows 内置的服务
- 兼容IE6的第一步就是单独对IE进行兼容,你针对IE6所写的代码只影响IE6;有几种方法可以区分开IE6:IE特有条件注释、CSS选择器、J
- 第一步 : 从清华大学开源软件镜像站下载Anaconda:https://mirrors.tuna.tsinghua.edu.cn/anac
- 数学函数 1.绝对值 S:select abs(-1) value O:select abs(-1) value from dual 2.取
- 过去一段时间人们似乎又非常热衷于探讨网络文档的印刷格式,涌现了很多与之相关的技术与理论资料,其中相当重要的一个领域就是关于印刷中字号和行高的
- 前言在 Qt 中可以使用信号和槽机制很方便地实现部件之间的通信,考虑下面这样的场景:我想要点击任意一个专辑卡并通知主界面跳转到专辑界面,那么
- 组合集总计: group by with rollup/cube grouping sets 子查询按执行方式分:标准子查询、关联子查询 标
- 我们来看看MD5加密码的实现:注意看一下他数据库里的加密位数!先在通用处申明:Private Const BITS_TO
- 下面我们以论坛排行榜举例说明:<% @ LANGUAGE="VBSCRIPT" %&
- 本文介绍了保护MySQL数据库中重要数据受外部攻击的六个注意事项,以减少面临的风险。与自动的数据库备份不同,对系统管理员来说,保护数据免受未
- jquery基本入门 第一天:选择器相关 1.html()与.text() .html()取得第一个匹配元素的html内容。会带有标签,.t
- 在ASP中,直接使用“Insert into” 语句与使用ADO中AddNew方法有什么区别?哪一种更好呢?AddNew方法的实质就是封装了
- 内容摘要:一堆数据摆面前,数据背后有什么样的事情在发生,这些数据里面暗藏着什么样的用户需求,什么样的商业机会?看懂这些,将为未来产品设计的方
- IE 浏览器中 CSS Expression 特性的最大的问题:会反复执行,每秒钟可能执行了成百上千次,有严重的性能问题。如何对 CSS E
- 1 Kmean图像分割按照Kmean原理,对图像像素进行聚类。优点:此方法原理简单,效果显著。缺点:实践发现对于前景和背景颜色相近或者颜色区
- jupyter介绍jupyter的全称为Jupyter Notebook,之前一度被称为(IPython notebook),是一种交互式的
- 代码如下:'返回某年总共有多少天 Function DayOfYear(ByVal y) DayOfYear = DatePart(
- 关联模型(多对多)多对多关系(抽象)例:一篇文章可能有多个关键词,一个关键词可能被多个文章使用。 关键词表:字段id主键字段keyword关