python里把协程变成任务

本文介绍如何使用Python的asyncio库中的ensure_future函数来封装协程为任务,并通过示例代码展示了如何传递这些任务并等待它们完成。

在这里使用 ensure_future()函数可以把一个协程封装成一个任务,然后这个任务就可以传送给别的代码,不过要注意的是这个函数不会开始执行协程,需要使用关键await才会开始执行:

import asyncio


async def wrapped():
    print('wrapped')
    return 'result'


async def inner(task):
    print('inner: starting')
    print('inner: waiting for {!r}'.format(task))
    result = await task
    print('inner: task returned {!r}'.format(result))


async def starter():
    print('starter: creating task')
    task = asyncio.ensure_future(wrapped())
    print('starter: waiting for inner')
    await inner(task)
    print('starter: inner returned')


event_loop = asyncio.get_event_loop()
try:
    print('entering event loop')
    result = event_loop.run_until_complete(starter())
finally:
    event_loop.close()
输出结果如下:

entering event loop
starter: creating task
starter: waiting for inner
inner: starting
inner: waiting for <Task pending coro=<wrapped() running at D:/work/csdn/python_Game1/example/asyncio_ensure_future.py:4>>
wrapped
inner: task returned 'result'
starter: inner returned

Python游戏开发入门

你也能动手修改C编译器

纸牌游戏开发

http://edu.csdn.net/course/detail/5538 

五子棋游戏开发

http://edu.csdn.net/course/detail/5487
RPG游戏从入门到精通
http://edu.csdn.net/course/detail/5246
WiX安装工具的使用
http://edu.csdn.net/course/detail/5207
俄罗斯方块游戏开发
http://edu.csdn.net/course/detail/5110
boost库入门基础
http://edu.csdn.net/course/detail/5029
Arduino入门基础
http://edu.csdn.net/course/detail/4931
Unity5.x游戏基础入门
http://edu.csdn.net/course/detail/4810
TensorFlow API攻略
http://edu.csdn.net/course/detail/4495
TensorFlow入门基本教程
http://edu.csdn.net/course/detail/4369
C++标准模板库从入门到精通 
http://edu.csdn.net/course/detail/3324
跟老菜鸟学C++
http://edu.csdn.net/course/detail/2901
跟老菜鸟学python
http://edu.csdn.net/course/detail/2592
在VC2015里学会使用tinyxml库
http://edu.csdn.net/course/detail/2590
在Windows下SVN的版本管理与实战 
http://edu.csdn.net/course/detail/2579
Visual Studio 2015开发C++程序的基本使用 
http://edu.csdn.net/course/detail/2570
在VC2015里使用protobuf协议
http://edu.csdn.net/course/detail/2582
在VC2015里学会使用MySQL数据库
http://edu.csdn.net/course/detail/2672


### 回答1: 协程(Coroutine)是一种轻量级的线程,也被称为用户级线程,由用户控制调度,而不是由操作系统控制。在 Python 中,协程是通过生成器实现的。 协程的特点是可以在执行过程中暂停并保存当前状态,然后在需要的时候恢复执行。这种特性使得协程在处理大量并发任务的时候非常高效。协程可以避免线程切换的开销,因为协程在同一个线程内执行,所以不需要进行线程切换,可以利用 CPU 的时间片进行高效的并发处理。 在 Python 中,协程可以使用 asyncio 库实现。通过定义异步函数,可以将阻塞式的 I/O 操作转化为非阻塞式,从而实现高效的并发处理。在 asyncio 中,可以使用 await 关键字来挂起协程,等待异步操作的完成,然后再恢复执行。 总之,协程是一种非常高效的并发处理方式,可以提高程序的性能和响应速度。 ### 回答2: Python中的协程是一种轻量级的并发编程方式。它是一种特殊的函数或方法,可以在函数执行过程中暂停,并且在稍后的某个时候继续执行,而不是一次性地运行完整个函数。 与传统的多线程或多进程编程不同,协程是单线程下的并发编程方式,它可以在一个线程中实现多个任务的并行执行。这种并发模型的好处在于减少了线程切换的开销,并且不需要使用锁来进行同步操作,避免了线程安全问题和死锁等常见的多线程编程难题。 在Python中,可以使用asyncio库来实现协程。通过使用async和await关键字,我们可以将普通的函数变成协程函数,并在其中使用异步操作。协程函数可以包含多个异步操作,这些操作可以是IO操作、网络请求、数据库查询等。 协程的特点是可以暂时挂起当前的任务,并切换到其他任务执行,待到其他任务完成后再切换回来继续执行。这种切换是由协程框架自动完成的,开发者无需关心具体的切换逻辑。这样可以大大提高程序的执行效率,特别适合处理IO密集型的任务。 总结来说,Python中的协程是一种并发编程方式,可以在一个线程中实现多个任务的并发执行。它的特点是轻量、高效,能够提高程序的执行效率,特别适合处理IO密集型的任务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

caimouse

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值