[英]For comprehension Dynamic List of Futures : Scala
我试图用于理解以执行一系列的期货清单。 一个未来的输出成为下一未来的输入。 下面是示例代码。
for {
x <- plugins(0).execute(input)
y <- plugins(1).execute(x)
z <- plugins(2).excute(y)
} yield z
上面的代码更像瀑布,每个插件(i)在某些输入上执行,然后将输出传递给下一个插件。 最后一个插件的输出是最终输出。 plugins是一个Seq of Plugin对象。 execute方法返回Future。 我想使上面的代码更通用,其中Plugins中插件的数量是动态的。 我该如何实施它。
plugins.foldLeft(Future.successful(input)) { (resultFuture, plugin) =>
resultFuture.flatMap(plugin.execute(_))
}
查看这些链接,看看是否了解这些功能的作用
Future.successful
只是将输入包装到Future中,以便我们可以像处理所有其他中间结果一样对待它。 下划线是lambda函数参数的快捷方式。 编写该片段的另一种方法是: resultFuture.flatMap { result => plugin.execute(result) }
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.