python在协程中增加任务

1、添加一个任务

task2=visit_url('http://another.com',3)
asynicio.run(task2)

2、这 2 个程序一共消耗 5s 左右的时间。并没有发挥并发编程的优势

importasyncio
importtime

asyncdefvisit_url(url,response_time):
"""访问url"""
awaitasyncio.sleep(response_time)
returnf"访问{url},已得到返回结果"

asyncdefrun_task():
"""收集子任务"""
task=visit_url('http://wangzhen.com',2)
task_2=visit_url('http://another',3)
awaitasyncio.run(task)
awaitasyncio.run(task_2)

asyncio.run(run_task())
print(f"消耗时间:{time.perf_counter()-start_time}")

3、如果是并发编程,这个程序只需要消耗 3s,也就是task2的等待时间。要想使用并发编程形式,需要把上面的代码改一下。asyncio.gather 会创建 2 个子任务,当出现 await 的时候,程序会在这 2 个子任务之间进行调度。

asyncdefrun_task():
"""收集子任务"""
task=visit_url('http://wangzhen.com',2)
task_2=visit_url('http://another',3)
awaitasynicio.gather(task1,task2)
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。