我正在尝试解决以下问题:
我有一个 Future[Map[A, B]]。对于所有 B,我需要应用一种将 B 转换为 Future[C] 的方法,并且我想返回一个 Future[Map[A, C]]
这是我到目前为止的代码:
def getClients(clientIds: Seq[Int]): Future[Map[Int, ClientData]] = {
def getClientData(clientInfo: ClientInfo): Future[ClientData] =
clientInfo match {
case ValidInfo(info) => getData(info)
case _ => throw new Exception
}
client.getClients(clientIds) map {
_.toMap map {
case (clientId: Int, clientInfo: ClientInfo) =>
getClientData(clientInfo) map {
clientData => (clientId, clientData)
}
}
}
}
此代码错误,因为它返回 Iterable[Future[(Int, ClientData)]]
对于信息getClients是一个节俭的方法,它返回Future[Map[A, B]]其中 Map 是可变的,所以我需要先用 toMap 将它转换为不可变的地图。
预先感谢您的帮助!