Scalaz Kleisli问题
-
23-09-2019 - |
题
还有一个 trait
叫 Kleisli 在 scalaz 图书馆。看码:
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)
不隶属于 StackOverflow