python asyncio回调函数_将带回调的Python函数转换为等待的asyncio

由于两个原因,相当于promisify不适用于此用例:

> PyAudio的异步API不使用asyncio事件循环 – 文档指定从后台线程调用回调.这需要预防措施才能正确地与asyncio通信.

>回调不能由单个未来建模,因为它被多次调用,而未来只能有一个结果.相反,它必须转换为异步迭代器,就像示例代码中所示.

这是一个可能的实现:

async def make_iter():

loop = asyncio.get_event_loop()

queue = asyncio.Queue()

def put(*args):

loop.call_soon_threadsafe(queue.put_nowait, args)

async def get():

while True:

yield queue.get()

return get(), put

make_iter返回一对< async iterator,put-callback>.返回的对象包含调用回调的属性,导致迭代器生成其下一个值(传递给回调的参数).可以调用回调来从任意线程调用,因此可以安全地传递给pyaudio.open,而异步迭代器应该在asyncio协同程序中被赋予async,在等待下一个值时它将被挂起:

async def main():

stream_get, stream_put = make_iter()

stream = pa.open(stream_callback=stream_put)

stream.start_stream()

async for in_data, frame_count, time_info, status in stream_get:

# ...

asyncio.get_event_loop().run_until_complete(main())

请注意,根据documentation,回调还必须返回有意义的值,帧元组和布尔标志.通过更改填充功能以从asyncio端接收数据,可以将其合并到设计中.不包括实现,因为没有对域的理解可能没有多大意义.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值