python3 異步模塊asyncio

yield方法引入,python

這裏存在的問題是,若是你想建立從0到1,000,000這樣一個很大的序列,你不得不建立能容納1,000,000個整數的列表。async

可是當加入了生成器以後,你能夠不用建立完整的序列,你只須要可以每次保存一個整數的內存便可。oop

import asyncio

@asyncio.coroutine
def countdown(number, n):
    while n > 0:
        yield from asyncio.sleep(1)
        print("T-minus", n, "({})".format(number))
        n -= 1
        if n == 10 and number=="A":
            raise ValueError

loop = asyncio.get_event_loop()

tasks = [
    asyncio.ensure_future(countdown("A", 20)),
    asyncio.ensure_future(countdown("B", 33)),
]
loop.run_until_complete(asyncio.wait(tasks))

loop.close()

 

 

看代碼spa

import asyncio

@asyncio.coroutine
def countdown(number, n):
    while n > 0:
        yield from asyncio.sleep(1)
        print("T-minus", n, "({})".format(number))
        n -= 1
        if n == 10 and number=="A":
            raise ValueError

loop = asyncio.get_event_loop()

tasks = [
    asyncio.ensure_future(countdown("A", 20)),
    asyncio.ensure_future(countdown("B", 33)),
]
loop.run_until_complete(asyncio.wait(tasks))

loop.close()

 

原理講的特別好code

http://python.jobbole.com/86481/orm

相關文章
相關標籤/搜索