当每个回调都有不同的参数时,将 Twisted Deferred 与并行回调一起使用

发布于 2024-10-19 11:51:08 字数 388 浏览 3 评论 0原文

我想创建一个延迟,如下所示:

f1(x1)f2(x2) 并行执行(可以这么说) 完成后,我运行 f3() 如果我有相同的参数,我会运行:

d = Deferred()
d.addCallbacks(f1)
d.addCallbacks(f2)
d.addCallback(lambda x: f3())
d.callback(x1)

以便将 x1 传递给 f1f2。但我需要 f1 来获取 x1 等等。

我该怎么做?

谢谢。

I want to create a deferred as follows:

f1(x1) and f2(x2) are performed in parallel (so to speak)
and after they finish, I run f3()
If I had the same parameters, I'd run:

d = Deferred()
d.addCallbacks(f1)
d.addCallbacks(f2)
d.addCallback(lambda x: f3())
d.callback(x1)

So that I pass x1 to both f1 and f2. But I need f1 to get x1 and so forth.

How can I do this?

Thanks.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

挽袖吟 2024-10-26 11:51:08

我不确定我是否正确理解了您的用例,但这似乎是 DeferredList 效果特别好。

d1 = function_that_returns_a_deferred_1(x1)
d2 = function_that_returns_a_deferred_2(x2)
d = DeferredList([d1, d2])
d.addCallback(lambda ign: f3())

这样,只有当 d1 和 d2 都完成后,f3 才会被执行。

I am not sure, if I understood your use case right, but this seems to be something, where a DeferredList would work particularly well.

d1 = function_that_returns_a_deferred_1(x1)
d2 = function_that_returns_a_deferred_2(x2)
d = DeferredList([d1, d2])
d.addCallback(lambda ign: f3())

This way, f3 will only be executed once both d1 and d2 have completed.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文