本文介绍了科鲁廷从未被期待过的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我使用的是一个简单的上下文管理器,里面有一个异步循环:

class Runner:
    def __init__(self):
        self.loop = asyncio.get_event_loop()

    def __enter__(self):
        return self

    def __exit__(self, *args):
        self.loop.close()

    def do_work(self):
        ...
        return self.loop.run_until_complete(asyncio.gather(*futures))

当我使用两个Runner对象时,我收到"Coroutine从未等待过"错误。

with Runner() as r:
    r.do_work()

with Runner() as r2:
    r2.do_work()

因为在第一个Runner(R)中关闭了一个循环。如果我不在exit中关闭循环,则一切正常,但我不需要使其保持打开状态。我知道一个线程中只能有一个循环,但是为什么它不等到RUN_TORK_COMPLETE?

推荐答案

可能会发生这样的情况:

import asyncio


async def test():
    await asyncio.sleep(0.1)


if __name__ ==  '__main__':
    loop = asyncio.get_event_loop()

    loop.run_until_complete(test())
    loop.close()

    loop.run_until_complete(test())

结果:

RuntimeError: Event loop is closed
sys:1: RuntimeWarning: coroutine 'test' was never awaited

如何解决此问题?

因为您以这种方式使用事件循环,所以每次都只能使用newevent loop

class Runner:
    def __init__(self):
        self.loop = asyncio.new_event_loop()  # *new*_event_loop


    def do_work(self):
        # Make sure all futures are created
        # with relevant event loop been set as current
        asyncio.set_event_loop(self.loop)

        # ...
        return self.loop.run_until_complete(asyncio.gather(*futures))

这篇关于科鲁廷从未被期待过的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

05-27 10:02