我有多个值 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
typeclasses在这里能帮到你吗?
应用一个由以下人员给出的提示 @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.Error