作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Web 应用程序中,我有一个操作可能会以各种不同的方式失败,或者最终会成功。
在这种情况下,成功和失败由 SimpleResult 的子类表示(表示 HTTP 响应)
我使用 scalaz/上的 monadic 操作来编码我的算法,例如:
val result = for {
user <- fetchUser \/> Forbidden("you must be connected to perform this action")
basket <- user.basket \/> NotFound("no basket !")
...
} yield Ok(someBasketView(user, basket))
SimpleResult \/ SimpleResult
我必须这样写:
result fold (identity, identity)
最佳答案
标准库和 Scalaz 都将此操作提供为 merge
:
scala> val e: Either[String, String] = Right("a")
e: Either[String,String] = Right(a)
scala> e.merge
res0: String = a
scala> import scalaz._, Scalaz._
import scalaz._
import Scalaz._
scala> val ez: String \/ String = "a".right
ez: scalaz.\/[String,String] = \/-(a)
scala> ez.merge
res1: String = a
SimpleResult
很难说这是否是对析取的合法使用——通常您会在构造函数中捕获有关结果是否失败的信息。
关于scala - 折叠\/[A,A] 到 A,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24365943/
我是一名优秀的程序员,十分优秀!