rai*_*hoo 4 generics polymorphism scala
我有scala泛型的问题.虽然我在这里定义的第一个函数似乎完全可以,但编译器抱怨第二个定义:
error: Parameter type in structural refinement may not refer to an abstract type defined outside that refinement
def >>[B](a: C[B])(implicit m: Monad[C]): C[B] = {
^
Run Code Online (Sandbox Code Playgroud)
我在这做错了什么?
trait Lifter[C[_]] {
implicit def liftToMonad[A](c: C[A]) = new {
def >>=[B](f: A => C[B])(implicit m: Monad[C]): C[B] = {
m >>= (c, f)
}
def >>[B](a: C[B])(implicit m: Monad[C]): C[B] = {
m >> a
}
}
}
Run Code Online (Sandbox Code Playgroud)
重要提示:这不是关于Monads的问题,这是一个关于scala多态性的问题.
编辑:这是我的Monad定义
trait Monad[C[_]] {
def >>=[A, B](a: C[A], f: A => C[B]): C[B]
def >>=[B](a: C[B]): C[B]
def apply[A](a: A): C[A]
}
Run Code Online (Sandbox Code Playgroud)
顺便说一句:我正在使用scala 2.8RC1
问候,raichoo
Ran*_*ulz 10
填写你的例子中的空白,我做了这个编译:
trait Monad[C[_]] {
def >>=[A, B](f: A => C[B]): C[B]
def >>[B](a: C[B]): C[B]
}
trait Lifter[C[_]] {
class D {
def >>=[A, B](f: A => C[B])(implicit m: Monad[C]): C[B] = {
m >>= f
}
def >>[B](a: C[B])(implicit m: Monad[C]): C[B] = {
m >> a
}
}
implicit def liftToMonad[A](c: C[A]) = new D
}
Run Code Online (Sandbox Code Playgroud)