Scala:"结构细化中的参数类型可能不会引用在该细化之外定义的抽象类型"

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)