未找到隐式值 类测试{ 导入scala.collection_ 班级家长 类子级扩展父级 隐式val children=mutable.Map[String,Child]() 定义createEntities[T } }
编译器抱怨的原因: 错误:找不到参数映射的隐式值:scala.collection.mutable.map[String,T] name.foreach(createEntity[T])未找到隐式值 类测试{ 导入scala.collection_ 班级家长 类子级扩展父级 隐式val children=mutable.Map[String,Child]() 定义createEntities[T } },scala,implicit,Scala,Implicit,编译器抱怨的原因: 错误:找不到参数映射的隐式值:scala.collection.mutable.map[String,T] name.foreach(createEntity[T]) ?如果您调用,例如,createEntities[Parent](“A”,“B”)(您可以这样做,因为Parent是Parent的子类型),它需要一个隐式的可变.Map[String,Parent],而没有。更准确地说,您的定义要求您提供一个可变.Map[String,t]对于父项的每个子类型,而不仅仅是那些已
?如果您调用,例如,
createEntities[Parent](“A”,“B”)
(您可以这样做,因为Parent
是Parent
的子类型),它需要一个隐式的可变.Map[String,Parent]
,而没有。更准确地说,您的定义要求您提供一个可变.Map[String,t]
对于父项的每个子类型,而不仅仅是那些已经定义的子类型:
class Test {
import scala.collection._
class Parent
class Child extends Parent
implicit val children = mutable.Map[String, Child]()
def createEntities[T <: Parent](names: String*) = names.foreach(createEntity[T])
def createEntity[T <: Parent](name: String)(implicit map: mutable.Map[String, T]): Unit = map.get(name) match {
case None => println( name + " not defined.")
case _ =>
}
}
implicit def aMap[T它是需要隐式参数的names.foreach(createEntity[T])
调用。如果删除此调用,它当然会编译!明白了。调用:createEntity[Child]()而不是createEntity[T]()是合法的,因为mutable.Map[String,Child]有隐式值,但mutable.Map[String,T]没有隐式值
implicit def aMap[T <: Parent]: mutable.Map[String, T] = ...