[英]Cats - how to use for-comprehension when `Monad` instance in scope?
如何在下面的方法中对M
型使用for-comprehension?
def foo[M[_]: Monad](m1: M[Int], m2: M[Int]) =
for {
a <- m1
b <- m2
} yield (a + b)
我会得到一个
value flatMap is not a member of type parameter M[Int]
我可以通过定义flatMap
和map
方法来实现它:
implicit class MOps[A](m: M[A])(implicit monad: Monad[M]) {
def flatMap[B](f: A => M[B]): M[B] = monad.flatMap(m)(f)
def map[B](f: A => B): M[B] = monad.map(m)(f)
}
但是肯定有必要让Cats提供这些方法吗?
尝试:
import cats.syntax.functor._, cats.syntax.flatMap._
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.