Asyncio Semaphore

新的启动事件循环

import asyncio
import logging
from contextlib import closing

import nest_asyncio

nest_asyncio.apply( )  # 在jupyter需要这个,不然asyncio运行出错
logging.basicConfig(  # 用日志打印输出信息
    level = logging.INFO,
    format = "%(asctime)s %(process)d %(thread)d [*] %(message)s"
)


async def myWorker(name, semaphore):
    await semaphore.acquire( )
    logging.info(f"{name}:成功获取信号量")
    await asyncio.sleep(3)
    logging.info(f"{name}:释放信号量")
    semaphore.release( )


async def main( ):
    logging.info("主协程")
    mySemaphore = asyncio.Semaphore(value = 2)  # 有界信号量(等待其中两个协程结束)
    await asyncio.wait([
        myWorker("A", mySemaphore),
        myWorker("B", mySemaphore),
        myWorker("C", mySemaphore),
        myWorker("D", mySemaphore),
        myWorker("E", mySemaphore),
    ])


if __name__ == "__main__":
    # 修改了这里
    with closing(asyncio.get_event_loop( )) as loop:
        loop.run_until_complete(main( ))

旧的启动事件循环

import asyncio
import time
import logging
import nest_asyncio
nest_asyncio.apply()  # 在jupyter需要这个,不然asyncio运行出错
logging.basicConfig(  # 用日志打印输出信息
    level=logging.INFO,
    format="%(asctime)s %(process)d %(thread)d [*] %(message)s"
)


async def myWorker(semaphore):
    await semaphore.acquire()
    logging.info("成功获取信号量")
    await asyncio.sleep(3)
    logging.info("释放信号量")
    semaphore.release()


async def main(loop):
    logging.info("主协程")
    mySemaphore = asyncio.Semaphore(value=2)  # 有界信号量(等待其中两个协程结束)
    return await asyncio.wait([
        myWorker(mySemaphore),
        myWorker(mySemaphore),
        myWorker(mySemaphore),
    ])

if __name__ == '__main__':
    loop = asyncio.get_event_loop()
    try:
        done, pending = loop.run_until_complete(main(loop))
        logging.info("所有任务完成")
    except KeyboardInterrupt as e:
        asyncio.Task.all_tasks()
        asyncio.gather(*asyncio.Task.all_tasks()).cancel()
        loop.stop()
#         loop.run_forever()  # 在jupyter不能手动关闭
    finally:
        pass
#         loop.close()  # 在jupyter不能手动关闭

2019-11-15 17:32:19,892 12912 9828 [*] 主协程
2019-11-15 17:32:19,894 12912 9828 [*] 成功获取信号量
2019-11-15 17:32:19,896 12912 9828 [*] 成功获取信号量
2019-11-15 17:32:22,897 12912 9828 [*] 释放信号量
2019-11-15 17:32:22,901 12912 9828 [*] 释放信号量
2019-11-15 17:32:22,907 12912 9828 [*] 成功获取信号量
2019-11-15 17:32:25,916 12912 9828 [*] 释放信号量
2019-11-15 17:32:25,921 12912 9828 [*] 所有任务完成
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值