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)
实例扩展:
import asyncio from threading import Thread async def production_task(): i = 0 while True: # 将consumption这个协程每秒注册一个到运行在线程中的循环,thread_loop每秒会获得一个一直打印i的无限循环任务 asyncio.run_coroutine_threadsafe(consumption(i), thread_loop) # 注意:run_coroutine_threadsafe 这个方法只能用在运行在线程中的循环事件使用 await asyncio.sleep(1) # 必须加await i += 1 async def consumption(i): while True: print("我是第{}任务".format(i)) await asyncio.sleep(1) def start_loop(loop): # 运行事件循环, loop以参数的形式传递进来运行 asyncio.set_event_loop(loop) loop.run_forever() thread_loop = asyncio.new_event_loop() # 获取一个事件循环 run_loop_thread = Thread(target=start_loop, args=(thread_loop,)) # 将次事件循环运行在一个线程中,防止阻塞当前主线程 run_loop_thread.start() # 运行线程,同时协程事件循环也会运行 advocate_loop = asyncio.get_event_loop() # 将生产任务的协程注册到这个循环中 advocate_loop.run_until_complete(production_task()) # 运行次循环
到此这篇关于python在协程中增加任务实例操作的文章就介绍到这了,更多相关python在协程中增加任务内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
这里将介绍任务(task)与协程(co-routines)的相关信息,你可以据此判断什么时候该使用协程,什么时候该使用任务,或两者一起使用。值得注意的是,尽管二者使用的API不同,但是却无法通过使用队列或者信号量来相互传递数据。 对于协程,实际上仅仅针对那些RAM空间很小的嵌入式系统,否则不推荐使用。 任务的特点 使用RTOS构建的实时应用是有一系列的任务组成,每个任务各自拥有自己的堆栈用于存储自
本文向大家介绍python多进程操作实例,包括了python多进程操作实例的使用技巧和注意事项,需要的朋友参考一下 由于CPython实现中的GIL的限制,python中的多线程其实并不是真正的多线程,如果想要充分地使用多核CPU的资源,在python中大部分情况我们需要使用多进程。 这也许就是python中多进程类库如此简洁好用的原因所在。在python中可以向多线程一样简单地使用多进程。 一、
本文向大家介绍python协程用法实例分析,包括了python协程用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了python协程用法。分享给大家供大家参考。具体如下: 把函数编写为一个任务,从而能处理发送给他的一系列输入,这种函数称为协程 希望本文所述对大家的Python程序设计有所帮助。
本文向大家介绍python实现的MySQL增删改查操作实例小结,包括了python实现的MySQL增删改查操作实例小结的使用技巧和注意事项,需要的朋友参考一下 本文实例总结了python实现的MySQL增删改查操作。分享给大家供大家参考,具体如下: 代码片段一 连接并执行sql 取数据 更新数据库 代码片段2 银行实例 更多关于Python相关内容感兴趣的读者可查看本站专题:《Python+MyS
本文向大家介绍Java线程协调运行操作实例详解,包括了Java线程协调运行操作实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Java线程协调运行操作。分享给大家供大家参考,具体如下: 一 点睛 借助于Object类提供的wait()、notify()和notifyAll()三个方法,可实现Java线程协调运行。这三个方法并不属于Thread类,而是属于Object类。但这三个方法
本文向大家介绍Python的IDEL增加清屏功能实例,包括了Python的IDEL增加清屏功能实例的使用技巧和注意事项,需要的朋友参考一下 为idle增加一个清屏的扩展ClearWindow就可以了(在http://bugs.python.org/issue6143中可以看到这个扩展的说明)。 下面我说安装使用的方法。首先下载clearwindow.py(点击可直接下载,不能下载的可以右键保存,格