[英]Future sequence to sequence of futures?
假设我有一个抽象的“生产者”实例:
trait Producer[T] {
def listObjectIds: Future[Seq[String]]
def getObject(id: String): Future[T]
}
而且我需要对它产生的每个(或某些)对象进行一些处理。 所以,我做类似的事情:
producer
.listObjectIds
.map(maybeFilter)
.map(_.map(producer.getObject))
...并以Future[Seq[Future[T]]]
结尾。没关系,但是有点麻烦。 我想摆脱外部的Future
,而只拥有Seq[Future[T]]
,但是想不出(非阻塞)转换,那会让我做到这一点。
有任何想法吗?
不可能以Seq[Future[T]]
结尾。 请参阅Future.sequence的反向 。
但是有可能以Future[Seq[T]]
结尾。 只需在Future[Seq[Future[T]]
上调用.flatMap(Future.sequence)
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.