使用 ayncio 實現 CountDownLatch

class CountDownLatch(object):
    def __init__(self, count=1):
        self.count = count
        self.lock = asyncio.Lock()
        self.event = asyncio.Event()
        

    async def count_down(self):
        with await self.lock:
            self.count -= 1
            if self.count <= 0:
                self.event.set()

    async def wait(self):
        await self.event.wait()

  網上沒找到好用的,本身實現了一個。python

 

測試:dom

async def test(latch : CountDownLatch, i):
    # await asyncio.sleep(random.random() * 2)
    print('{} work complete'.format(i))
    await latch.count_down()
    
async def main():
    try:
        for j in range(0, 10):
            print('turn start')            
            latch = CountDownLatch(20)
            for i in range(0, 20):
                asyncio.ensure_future(test(latch, i))
            await latch.wait()
            print("20 tasks complete")
            await asyncio.sleep(2)
    except Exception as e:
        print(e)
        
if __name__ == '__main__' :
    loop = asyncio.get_event_loop();
    loop.run_until_complete(asyncio.wait([main()]))    
相關文章
相關標籤/搜索