我正在尝试用Python实现一个简单的actor系统来开发关于并发编程的一些见解。
我主要担心的是使用该asyncio模块在Python中编写期货的一般任务。
假设我在一个单独的Thread上运行了一个事件循环。import asyncio
from threading import Thread
loop = asyncio.new_event_loop()
def run_event_loop(loop):
asyncio.set_event_loop(loop)
loop.run_forever()
t = Thread(target=run_event_loop, args=(loop,))
t.start()
为了避免同步通信,我需要能够以Futures某种方式编写。作为一个简单的例子,假设我想要结合两个async协同程序的结果。
我的第一次(显然是错误的)尝试:async def f(x):
fut = asyncio.run_coroutine_threadsafe(g(x / 2), loop)
return fut
async def g(x):
return x * 2
f(x) = x / 2
g(x) = x * 2
f(g(x)) = x
我无法得到一个干净的解决方案来解决以下一般问题:x = 10
future = asyncio.run_coroutine_threadsafe(f(x), loop)
print(future) #
print(future.result()) #
print(future.result().result()) # 10.0
理想情况下,我应该结合未来并future.result()在最后执行单一。或者也许我错误地考虑了所有这些。