我正在阅读有关将值提升为Monad变形金刚的this文档。
基于此,我写了以下代码
import cats.data._
import cats.implicits._
type FutureOption[T] = OptionT[Future, T]
val x : FutureOption[Int] = 1.pure[FutureOption] // works
val y : FutureOption[Int] = OptionT.fromOption[Future](Some(10)) // works
val z : FutureOption[Int] = OptionT.liftF(Future.successful(10)) // works
现在,如果我尝试
val z = FutureOption[Int] = OptionT(Future.successful(Some(10)))
我收到错误
cmd4.sc:1: no type parameters for method apply: (value: F[Option[A]])cats.data.OptionT[F,A] in object OptionT exist so that it can be applied to arguments (scala.concurrent.Future[Some[Int]])
--- because ---
argument expression's type is not compatible with formal parameter type;
found : scala.concurrent.Future[Some[Int]]
required: ?F[Option[?A]]
val x : OptionT[Future, Int] = OptionT(Future.successful(Some(10)))
^
cmd4.sc:1: type mismatch;
found : scala.concurrent.Future[Some[Int]]
required: F[Option[A]]
val x : OptionT[Future, Int] = OptionT(Future.successful(Some(10)))
^
cmd4.sc:1: type mismatch;
found : cats.data.OptionT[F,A]
required: cats.data.OptionT[scala.concurrent.Future,Int]
val x : OptionT[Future, Int] = OptionT(Future.successful(Some(10)))
答案 0 :(得分:3)
错误是由于Scala类型推断造成的。
如果没有明确的Option
类型注释,则Some(10)
的类型为Some[Int]
,这是Option[Int]
的子类型。但是OptionT
完全需要Option
,因此无法编译。
您可以通过执行
进行编译val z: FutureOption[Int] = OptionT(Future.successful(Option(10)))
或
val z: FutureOption[Int] = OptionT(Future.successful(Some(10): Option[Int]))
答案 1 :(得分:1)
Gabrielle提供的解决方案的替代方案。您可以使用cats lib
提供的语法import cats.syntax.option._
然后
val z: FutureOption[Int] = OptionT(Future.successful(10.some))
Or
val z: FutureOption[Int] = OptionT(Future.successful(none[Int]))
10.some
和none[Int]
将被推断为Option[Int]
P.S:还有一种语法,可以通过cats.syntax.either._
10.asRight[String]
来将"Oops".asLeft[Int]
推断为Either[String, Int]