关于 Scala implicits with multiple type parameters 的问题

Question about Scala implicits with multiple type parameters

我很难理解与“找不到隐含值”错误相关的错误。这是突出显示错误的最小示例。

sealed trait BehaviourA
final case object A1 extends BehaviourA
final case object A2 extends BehaviourA

sealed trait BehaviourB
final case object B1 extends BehaviourB
final case object B2 extends BehaviourB

trait factory[O<:BehaviourA, R<:BehaviourB]{ ... }

// Define an implicit value for each combination of the two behaviours
object factory {
  implicit val behaviour1 = new factory[A1, B1] { ... }
  ... (one for each Ai, Bj)
}

object genElement {
  import factory._

  def apply[O <: BehaviourA, R<:BehaviourB](...)(implicit c: factory[O, R])
}

然而,当我尝试从另一个方法调用它时,它抱怨在 genExample 中找不到隐式 c 的值。

def callerMtd[T<:BehaviourA](){
  genElement[T, B1](...)
}

or 

def callerMtd[T<:BehaviourA, R<:BehaviourB](){
  genElement[T, R](...)
}

如果我像下面这样直接调用它们就可以了。为什么我不能在调用方法中使用类型参数?

def callerMtd(){
  genElement[A1, B2](...)
}

即使类型是密封的,而且您似乎提供了所有类型 class 个实例

(one for each Ai, Bj)

这并未涵盖

中类型范围指定的所有可能情况
def callerMtd[T <: BehaviourA, R <: BehaviourB]

例如,这里有适合边界的类型,但您可能没有为它们提供实例

callerMtd[A1.type with A2.type, B1.type with B2.type]

为了确保编译器可以为 factory[T, R] 调用一个实例,其中 T <: BehaviourAR <: BehaviourB 您必须指示它如何使用相应的隐式 def[=17 生成它=]

implicit def foo[T <: BehaviourA, R <: BehaviourB]