Я играл с ListW.<^>
a>, определение которого выглядит следующим образом:
def <^>[B: Zero](f: NonEmptyList[A] => B): B = value match {
case Nil => ∅
case h :: t => f(Scalaz.nel(h, t))
}
Я не могу понять, почему Option
выбран в качестве типа Zero
для этого примера.
scala> case class CC(v : Int)
defined class CC
scala> val posns = List(CC(2), CC(5), CC(1))
posns: List[CC] = List(CC(2), CC(5), CC(1))
Итак, теперь у меня есть Список этих вещей. Моя цель - вернуть Option[CC]
для минимального/максимального значения posns
, где я получаю None
для минимального, если нет значений ниже нуля и аналогичных для максимального.
scala> import scalaz._; import Scalaz._
import scalaz._
import Scalaz._
scala> implicit val CCOrder = new Order[CC] {
| def order(v1 : CC, v2 : CC) = orderBy( (v : CC) => v.v ).order(v1, v2)
| }
CCOrder: java.lang.Object with scalaz.Order[CC] = $anon$1@1e48d65
scala> posns.filter(_.v < 0) <^> (_.min)
res0: Option[CC] = None
scala> posns.filter(_.v > 0) <^> (_.max)
res1: Option[CC] = Some(CC(5))
Option был точно Zero
типа, который я хотел! Может ли кто-нибудь объяснить, как машинист выбирает Option
? Я не заявляю об этом нигде!