异步的语义等价于

时间:2016-06-29 14:10:08

标签: python python-asyncio

从Python 3.5中相对于async for语法的文档中,我收集到它是为了迭代一个等待的迭代器而引入的。

尽管如此,我仍然无法获得符合描述的语义等价物:

iter = (ITER)
iter = type(iter).__aiter__(iter)
running = True
while running:
    try:
        TARGET = await type(iter).__anext__(iter)
    except StopAsyncIteration:
        running = False
    else:
       BLOCK
else:
    BLOCK2 

iter = type(iter).__aiter__(iter)行在做什么?为什么有必要?

1 个答案:

答案 0 :(得分:3)

python中的魔术方法,例如__add__总是 looked up on the class。例如,len(foo)实际上调用解析为type(foo).__len__(foo)。这意味着如果在foo.__len__上定义了__len__永远不会使用foo。 [1]

由于__aiter__是一种神奇的方法,因此它总是被查找为type(foo).__aiter__(foo)

查找示例:

class Thingy(object):
  def __len__(self):
    return 10

lengthy_thingy = Thingy()
lengthy_thingy.__len__ = lambda self: 20

print(len(lengthy_thingy))  # gives `10`
print(lengthy_thingy.__len__(lengthy_thingy))  # gives `20` instead
print(type(lengthy_thingy).__len__(lengthy_thingy))  # gives `10` as for using `len`