python在协程中增加任务
- 更新时间:2021-07-06 09:54:43
- 编辑:浦鸿博
给网友朋友们带来一篇相关的编程文章,网友扶英卓根据主题投稿了本篇教程内容,涉及到Python相关内容,已被286网友关注,内容中涉及的知识点可以在下方直接下载获取。
参考资料
- Python从入门到精通 PDF 电子书 / 66.6 MB / 陈政强 推荐度:
- 《Python数据分析与数据化运营》附件 配套资源 / 106.5 MB / 宋天龙 推荐度:
- Python数据可视化之matplotlib精进 PDF 电子书 / 104 MB / 刘大成 推荐度:
- Python设计模式(第2版) PDF 电子书 / 21.9 MB / 吉里德尔 推荐度:
- Python数据分析入门:从数据获取到可视化 PDF 电子书 / 5.4 MB / 沈祥壮 推荐度:
正文内容
小编给大家总结一篇《python在协程中增加任务》的技术内容,代码整理的很实用,重新排版了一下发到这里,为了大家阅读方便。
1、添加一个任务
task2 = visit_url('http://another.com', 3) asynicio.run(task2)
2、这 2 个程序一共消耗 5s 左右的时间。并没有发挥并发编程的优势
import asyncio import time async def visit_url(url, response_time): """访问 url""" await asyncio.sleep(response_time) return f"访问{url}, 已得到返回结果" async def run_task(): """收集子任务""" task = visit_url('http://wangzhen.com', 2) task_2 = visit_url('http://another', 3) await asyncio.run(task) await asyncio.run(task_2) asyncio.run(run_task()) print(f"消耗时间:{time.perf_counter() - start_time}")
3、如果是并发编程,这个程序只需要消耗 3s,也就是task2的等待时间。要想使用并发编程形式,需要把上面的代码改一下。asyncio.gather 会创建 2 个子任务,当出现 await 的时候,程序会在这 2 个子任务之间进行调度。
async def run_task(): """收集子任务""" task = visit_url('http://wangzhen.com', 2) task_2 = visit_url('http://another', 3) await asynicio.gather(task1, task2)
以上就是python在协程中增加任务的方法,希望能对大家有所帮助。更多Python学习指路:
相关教程
-
Python语言实现百度语音识别功能的实例
未来的一段时间,人工智能在市场上占有很重的位置,Python语言则是研究人工智能的最佳编程语言,下面,就让我们来感受一下它的魅力吧! 百度给的样例程序,不论C还是Java版,都分为metho
发布时间:2019-07-11
-
python manim实现排序算法动画示例
这篇文章主要为大家介绍了python manim实现排序算法动画示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
发布时间:2019-07-23