- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
使用我见过的 asyncio
库,
@asyncio.coroutine
def function():
...
和
async def function():
...
可以互换使用。
两者在功能上有区别吗?
最佳答案
是的,使用 async def
语法的原生协程和使用 asyncio.coroutine
装饰器的基于生成器的协程之间存在功能差异。
根据PEP 492 ,其中引入了 async def
语法:
Native coroutine objects do not implement
__iter__
and__next__
methods. Therefore, they cannot be iterated over or passed toiter()
,list()
,tuple()
and other built-ins. They also cannot be used in afor..in
loop.An attempt to use
__iter__
or__next__
on a native coroutine object will result in a TypeError .Plain generators cannot
yield from
native coroutines: doing so will result in a TypeError .generator-based coroutines (for asyncio code must be decorated with
@asyncio.coroutine
) canyield from
native coroutine objects.
inspect.isgenerator()
andinspect.isgeneratorfunction()
returnFalse
for native coroutine objects and native coroutine functions.
上面的第 1 点意味着虽然使用 @asyncio.coroutine
装饰器语法定义的协程函数可以像传统的生成器函数一样运行,但使用 async def
语法定义的协程函数则不能。
这里有两个最小的,表面上等效的协程函数,用两种语法定义:
import asyncio
@asyncio.coroutine
def decorated(x):
yield from x
async def native(x):
await x
虽然这两个函数的字节码几乎相同:
>>> import dis
>>> dis.dis(decorated)
5 0 LOAD_FAST 0 (x)
3 GET_YIELD_FROM_ITER
4 LOAD_CONST 0 (None)
7 YIELD_FROM
8 POP_TOP
9 LOAD_CONST 0 (None)
12 RETURN_VALUE
>>> dis.dis(native)
8 0 LOAD_FAST 0 (x)
3 GET_AWAITABLE
4 LOAD_CONST 0 (None)
7 YIELD_FROM
8 POP_TOP
9 LOAD_CONST 0 (None)
12 RETURN_VALUE
...唯一的区别是 GET_YIELD_FROM_ITER
与 GET_AWAITABLE
,当尝试迭代它们返回的对象时,它们的行为完全不同:
>>> list(decorated('foo'))
['f', 'o', 'o']
>>> list(native('foo'))
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'coroutine' object is not iterable
显然 'foo'
不是可等待的,因此尝试用它调用 native()
没有多大意义,但希望这一点很清楚它返回的 coroutine
对象是不可迭代的,不管它的参数是什么。
Brett Cannon 对 async
/await
语法的更详细调查:How the heck does async/await work in Python 3.5?更深入地涵盖了这种差异。
关于python - @asyncio.coroutine 与 async def,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40571786/
有人可以解释一下接下来的事情有什么区别吗? def self.up 定义 def self.down 下 最佳答案 self.up和up包含执行rake db:migrate时由迁移运行的代码。 se
我在从第三个(主)函数调用前两个函数时遇到问题。我相信我的编码正确(忽略大小和 x,y 坐标)来显示 di 的五边,但似乎无法弄清楚如何调用这些函数。 主要目标是显示 di 的五个面。 def dot
我想做这样的事情: class MyClass(Object): def ****(self): print self.__name __ MyClass.test() ->t
我只是环顾四周,以减少在 liquibase 上创建表的工作量和错误。 是否可以为表创建一组默认列? 列: 内部ID 可变字符 UUID 时间戳创建Ts 时间戳更新Ts int 锁定版本 约束 ID
在注释宏中,我枚举了一个类的成员,并且想要找到我找到的方法的类型。 所以我很高兴地遍历 body类的,并收集所有DefDef成员。 ...我无法进行类型检查。 对于每个 DefDef我尝试将其包装在
我正在查看的一些代码中的示例 class X { def k1 = column[Int]("k1") def k2 = column[Int]("k2") def * = (
我是一个时髦的初学者。 我很困惑是否使用了“def”。 def str = "hello" print str 对比 str = "hello" print str 从这个例子。结果是一样的。但我想知
我想做这样的事情: class Result<
我正在尝试理解这个函数。 我看到的是一个属性和类型被传递给了 opal () 方法。 然后type_name取值自 type只要type是 Symbol或 String .否则,name在 type
在此Haskell-like comprehensions implementation in Ruby有一些我在 Ruby 中从未见过的代码: class Array def +@ #
我的问题非常简单,但不幸的是我找不到解决方法。 我想运行一个 def A,它仅从 def B 返回多个值一次。 我写了这段代码: def A(): x = 1 y = 2 z
我在 def 声明中使用 Scalameta(v1.8.0) 注释: trait MyTrait { @MyDeclDef def f2(): Int } 定义的注释类只返回输入,如下所示:
写private[this] def与 private def 相比,在性能噪声比方面是有意义的?我知道这对 private[this] val 有影响超过 private val因为前者允许 sca
在下面的代码段(取自 Groovy Semantics Manual page )中,为什么要在赋值前加上关键字 def ? def x = 0 def y = 5 while ( y-- > 0 )
作为标题,Groovy中这两个定义的确切区别是什么? 也许是文档问题,我什么也找不到... 最佳答案 没有static的方法声明将方法标记为实例方法。带有static的声明将使此方法静态-可以在不创建
我正在使用 d3.js 强制导向图。它有节点和连接它们的链接。为了创建箭头,我使用 svg 和 d3 组合起来,如下所示: gA.svg.append('defs').selectAll('m
我经常看到包含 def execute(self) 和 def run() 的类 python 会像 C++ 中的 int main() 那样自动获取它吗? 最佳答案 Python 是一种解释型语言,
此代码无法编译: object Foo { implicit def toString(i: Int): String = i.toString def foo(x: String)
例如我需要在函数 def a[A:ClassManifest] 中访问 list 获得删除类。我可以使用 Predef.implicitly 函数,但在这种情况下,我的代码将与我使用完整形式 def
我知道scala中的空参数方法和无参数方法之间的用法差异,我的问题与生成的类文件有关。当我在javap中查看这两个类时,它们看起来完全相同: class Foo { def bar() = 123
我是一名优秀的程序员,十分优秀!