py002 asyncio condition

该博客演示了Python的asyncio库中条件变量(condition)的使用,通过一个 officer 角色触发事件,多个 worker 角色等待并响应事件来完成任务。示例展示了如何在并发环境中控制任务的执行顺序和同步。
摘要由CSDN通过智能技术生成
import asyncio
import functools
import random
import time
def notifier( cond, t):
''' set event '''
t2=time.time()-t
print( 'set_event ( %5.3f ) :trigger the event...'%t2)
cond.notify_all()
t2=time.time()-t
print( 'set_event ( %5.3f ) :trigger triggerred..'%t2)

async def worker( cond, name, t):
''' task '''
t2 = time.time() - t
print( 'worker ( %s )( %5.3f ) :start task' % (name, t2))
print( 'worker ( %s )( %5.3f ) :working for some seconds' % (name, t2))
await asyncio.sleep(random.random() * 3 + 2)
t2 = time.time() - t
print( 'worker ( %s )( %5.3f ) :afterwork,waiting for trigger' % (name, t2))
with await cond:
#此部分是被锁住的,看下面的执行时间就看出来了
await cond.wait()
t2 = time.time() - t
print( 'worker ( %s )( %5.3f ) :trigger was touched,i will do something.' % (name, t2))

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

async def officer( cond, t):
'''officer'''
await asyncio.sleep( 6.5)
with await cond:
notifier(cond,t)

async def main( loop):
'''main'''
cond=asyncio.Condition()
t1=time.time()
task=loop.create_task(officer(cond,t1))

workers=[worker(cond,i,t1) for i in range( 3)]
await asyncio.wait(workers)
task.cancel()



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


----------------------------------------------------------------------
worker (2)(0.000)  :start task
worker (2)(0.000)  :working for some seconds
worker (1)(0.001)  :start task
worker (1)(0.001)  :working for some seconds
worker (0)(0.001)  :start task
worker (0)(0.001)  :working for some seconds
worker (0)(2.295)  :afterwork,waiting for trigger
worker (2)(4.149)  :afterwork,waiting for trigger
worker (1)(4.264)  :afterwork,waiting for trigger
set_event  (6.506) :trigger the event...
set_event  (6.506) :trigger triggerred..
worker (0)(6.507)  :trigger was touched,i will do something.
worker (0)(8.748)  :my task is done.
worker (2)(8.748)  :trigger was touched,i will do something.
worker (2)(11.899)  :my task is done.
worker (1)(11.899)  :trigger was touched,i will do something.
worker (1)(15.157)  :my task is done.


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值