您应该只使用__init__。您将首先创建一个常规类实例,然后等待该实例。这是两个独立的操作。在
例如,您可以先创建实例,然后分别在和上等待它:my_class = MyClass(my_parameter)
result_from_coroutine = await my_class
或者,您可以从中创建一个任务,并让事件循环执行它
^{pr2}$
__await__方法是await或事件循环用来驱动协程的。同样的分离也适用于协程函数(用async def定义);当您调用它们时,它们也会创建一个新的协程对象,您不必立即等待它们。您可以在其他时间对结果使用await。在
如果您正在寻找异步实例创建,那么您可以通过将^{} method组合成一个协程来解决这个问题:>>> class Async:
... async def __new__(cls):
... instance = super().__new__(cls)
... return instance
...
>>> Async()
等待协同程序将创建实际实例并返回它。在
请注意,这确实意味着__init__方法将被跳过;后者只在__new__方法直接返回类(或子类)的实例时调用,而协程不是这样的实例。你必须自己明确地这样做:class Async:
async def __new__(cls, *args, **kwargs):
instance = super().__new__(cls)
instance.__init__(*args, **kwarg)
return instance
此时,您可以决定让__init__方法也成为一个协程。在
请注意,这实际上是一种与谷物背道而驰的做法。我会推迟调用依赖的协同程序到稍后的时候。在
例如,您可以将参数存储到实例上的类中,并在实例等待时使用这些参数(通过调用__await__),就像您链接到建议您要做的post一样。在