我有多个值F[A],它可能会以一些错误完成它们的评估。在发生错误时,需要执行一些操作。如何为执行所有值的处理程序,而不仅仅是发生错误的第一次?
例如
import cats.implicits._
import cats.effect._
class Test[F[_]: Sync] {
def executeAllHandlers[A, B, C](fa: F[A], fb: F[B], fc: F[C]): F[(A, B, C)] =
for {
a <- fa
b <- fb
c <- fc
} yield (a, b, c)
}
object Test extends App{
val ioa: IO[Int] = IO.raiseError(new Error) onError {
case _ => IO(println("ioa"))
}
val iob: IO[String] = IO.raiseError(new Error) onError {
case _ => IO(println("iob"))
}
val ioc: IO[Double] = 2.5.pure[IO]
//prints ioa and fails with Error
new Test[IO].executeAllHandlers(ioa, iob, ioc).unsafeRunSync()
}我想要实现的是,对所有错误的评估执行处理程序,在上面的情况下,这些评估是ioa和iob,并且失败时会出现错误(不管是哪一个)。
能在猫身上实现这样的目标吗?也许mtl类型的人在这里能帮上忙?
发布于 2020-06-04 18:00:54
应用@LuisMiguelMejíaSuárez给出的提示是如何修改函数,从而执行所有处理程序
def executeAllHandlers[A, B, C](fa: F[A], fb: F[B], fc: F[C]): F[(A, B, C)]=
(for {
a <- fa.attempt
b <- fb.attempt
c <- fc.attempt
} yield for {
a <- a
b <- b
c <- c
} yield (a, b, c)).flatMap(Sync[F].fromEither)现在,它执行两个处理程序,然后抛出Error。
ioa
iob
Exception in thread "main" java.lang.Errorhttps://stackoverflow.com/questions/62200781
复制相似问题