Store Promise in Map to resolve/reject later(将承诺存储在地图中以供以后解决/拒绝)
本文介绍了将承诺存储在地图中以供以后解决/拒绝的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我在NodeJS中的IPC上工作,希望能够从子进程向父进程发送消息并"等待"结果。我的想法是跟踪映射中的所有发送消息,该映射将唯一的消息ID映射到承诺。调用process.on('message`)
后,我将根据从父级返回的ID查找承诺,并希望解析或拒绝该承诺。
我想出了这个,但我被解决/拒绝部分卡住了:
有人能在如何解决这个问题上把我推向正确的方向吗?这是可能的最佳实践吗?
谢谢!
推荐答案
您不会将承诺存储在地图中。您将只存储稍后调用的解析器函数-承诺被创建并立即返回。
在Promise Executor之外的其他作用域中调用resolve
的情况很少,但消息传递是必要的情况之一,也是标准做法。顺便说一句,您可能需要考虑在响应接收上设置超时。
这篇关于将承诺存储在地图中以供以后解决/拒绝的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!