还有一个 traitKleisliscalaz 图书馆。看码:

import scalaz._
import Scalaz._
type StringPair = (String, String)

val f: Int => List[String]        = (i: Int) => List((i |+| 1).toString, (i |+| 2).toString)
val g: String => List[StringPair] = (s: String) => List("X" -> s, s -> "Y")

val k = kleisli(f) >=> kleisli(g) //this gives me a function: Int => List[(String, String)]

叫功能 k 值的2给出:

println( k(2) ) //Prints: List((X,3), (3,Y), (X,4), (4,Y))

我的问题是: 我怎么会使用Scalaz结合f和g得到一个功能m此类输出的m(2)将是:

val m = //??? some combination of f and g
println( m(2) ) //Prints: List((X,3), (X,4), (3,Y), (4,Y))

是这个可能吗?

有帮助吗?

解决方案

似乎你想要的 transpose.Scalaz不提供此,但应该可以很容易地编写。功能 m 你想要的是 val m = f andThen (_.map(g)) andThen transpose andThen (_.join)

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top