我对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] = {
^
我在这里做错了什么?
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
}
}
}
重要提示:这不是关于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]
}
BTW:我正在使用scala 2.8RC1
此致 raichoo
答案 0 :(得分: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
}
答案 1 :(得分:0)
谢谢,这确实有帮助。你的回答指引我走向正确的方向。我写了这个东西:
trait Lifter[C[_]] {
class Wrapper[A](c: C[A]) {
def >>=[B](f: A => C[B])(implicit m: Monad[C]): C[B] = {
m >>= (c, f)
}
def >>[B](b: C[B])(implicit m: Monad[C]): C[B] = {
m >> (c, b)
}
}
implicit def liftToMonad[A](c: C[A]): Wrapper[A] = new Wrapper(c)
}
非常感谢。
此致 raichoo