Skip to content

Instantly share code, notes, and snippets.

@cjgiridhar
Created September 21, 2014 06:12
Show Gist options
  • Save cjgiridhar/9813678fcaaac181ba18 to your computer and use it in GitHub Desktop.
Save cjgiridhar/9813678fcaaac181ba18 to your computer and use it in GitHub Desktop.
AsyncIO Parallel
import asyncio
@asyncio.coroutine
def factorial(name, number):
f = 1
for i in range(2, number+1):
print("Task %s: Compute factorial(%s)..." % (name, i))
yield from asyncio.sleep(1)
f *= i
print("Task %s: factorial(%s) = %s" % (name, number, f))
loop = asyncio.get_event_loop()
tasks = [
asyncio.async(factorial("A", 2)),
asyncio.async(factorial("B", 3)),
asyncio.async(factorial("C", 4))]
loop.run_until_complete(asyncio.wait(tasks))
loop.close()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment