功能性错误处理。执行所有处理程序

问题描述 投票:1回答:1

我有多个值 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() 
}

我想实现的是对所有错误的评估执行处理程序,在上面的案例中,这些错误的评估就是 ioaiob 并以错误的方式失败(不管是哪一种)。

有没有可能在猫咪身上实现这样的功能?也许可以 mtl typeclasses在这里能帮到你吗?

scala error-handling functional-programming scala-cats
1个回答
2
投票

应用一个由以下人员给出的提示 @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
© www.soinside.com 2019 - 2024. All rights reserved.