Учитывая следующий код:Каковы правила в Scala для решения противоречивых неявные значения
/**
* Created by danap on 12/8/15.
*/
object ImplicitTest {
trait EC {
override def toString : String = s"EC"
}
trait DEC extends EC {
def sub : EC
override def toString : String = s"DEC - $sub"
}
def usesEC(implicit ec : EC) = ec.toString
class B(implicit val dec: DEC) {
def whichEC = usesEC
}
class C(implicit val dec: DEC) {
implicit val _ec = dec.sub
def whichEC = usesEC
def whichECExplicit = usesEC(_ec)
}
def main(args:Array[String]): Unit = {
implicit val dec : DEC = new DEC {
val sub = new EC {}
}
val b = new B
val c = new C
println(s"b class = ${b.whichEC}")
println(s"c class = ${c.whichEC}")
println(s"c class = ${c.whichECExplicit}")
}
}
Выход для Скале 2.11:
b class = DEC - EC
c class = DEC - EC
c class = EC
Я ожидал, что это будет:
b class = DEC - EC
c class = EC
c class = EC
Поскольку неявный val _ec
объявлен «ближе» к вызову usesEC
в whichEC
. Почему это происходит? Кроме того, как я могу заставить _ec
использовать неявно в C.whichEC
?
Персональное правило №1 при использовании implicits в scala: никогда не имеет в области более одного типа, потому что вы никогда не знаете, кто переопределяет кого. –