py001 asyncio task test


import asyncio
import functools
import random
import time
def set_event( event, t):
''' set event '''
t2=time.time()-t
print( 'set_event ( %5.3f ) :trigger the event...'%t2)
event.set()
t2=time.time()-t
print( 'set_event ( %5.3f ) :trigger triggerred..'%t2)

async def task( event, name, t):
''' task '''
t2=time.time()-t
print( 'task ( %s )( %5.3f ) :start task' % (name, t2))
print( 'task ( %s )( %5.3f ) :working for some seconds' % (name, t2))
await asyncio.sleep(random.random()* 5)
t2 = time.time() - t
print( 'task ( %s )( %5.3f ) :afterwork,waiting for trigger' % (name, t2))
await event.wait()
t2 = time.time() - t
print( 'task ( %s )( %5.3f ) :trigger was touched,i will do something.' % (name, t2))

await(asyncio.sleep(random.random()* 3))
t2 = time.time() - t
print( 'task ( %s )( %5.3f ) :my task is done.' % (name, t2))

async def main( loop):
''' main '''
event=asyncio.Event()
t1=time.time()
print( 'main ( %5.3f ) :event states-- %s '%(t1,event.is_set()))
loop.call_later( 6.5, functools.partial(set_event, event, t1))
await asyncio.wait([task(event, i, t1) for i in range( 3)])
t2 = time.time() - t1
print( 'main ( %5.3f ) :event states-- %s '%(t2,event.is_set()))

loop=asyncio.get_event_loop()
loop.run_until_complete(main(loop))
loop.close()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值