导语:
本文主要介绍了关于python在协程中增加任务的相关知识,包括python异步多线程,以及python携程gevent这些编程知识,希望对大家有参考作用。
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安装完成无法使用怎么解决10/15
- ♥ Python如何实现定时发送qq消息10/13
- ♥ 哪个版本的python是免费的10/07
- ♥ Python的构造函数和析构函数是一样的吗?10/07
- ♥ numpy.append()中axis的三种用法介绍10/30
- ♥ 如何在python中无限循环08/22
内容反馈