我希望解决方案不会基于if-else的明显模式匹配。我相信应该有更自然的方法可以做到这一点,比如将map
和getOrElse
组合在选项上。
Validation
有一个fold
的方法,可以选择产生副作用:
v.fold(e => println("Ouch, we got "+e), a => println("Yay!! We got "+a))
Validation.fold
用字符填充答案...
为了完整起见,您可能希望在与验证产生副作用后对其进行操作:
object Test {
import scalaz._
import syntax.bifunctor._
import syntax.validation._
def f(s: String) = { println(s"Err ${s}"); s }
def g(i: Int) = { println(s"Int ${i}"); i }
def m(x: Validation[String, Int]) = x bimap (f, g)
def n(x: Validation[String, Int]) = f _ <-: x :-> g _
def main(args: Array[String]) {
val v = 17.success[String]
val w = "nope".failure[Int]
println(m(v) map (i => i + 1))
println(m(v)); println(m(w))
println(n(v)); println(n(w))
}
}
或者,您可能只是喜欢有脸的操作员。 表情符号运营商在功能社区中是否有名称? 鉴于我现在的心情,我会尝试像mope一样,但这可能太狭窄了。 还是"洛洛普"?但是像 x 这样的用法 :->f显然是一种"面部表情"。