Ho codice:errore con la definizione covariante e tipi controvarianti
class A {
override def toString = "object class A"
}
class B extends A {
override def toString = "object class B"
}
class Cell[+T](init: T) {
private[this] var current: T = init
def get: T = current
def set(x: T) { current = x }
}
val cB = new Cell[B](new B)
println(cB.get)
val cA: Cell[A] = cB
println(cA.get)
ma ho l'errore in linea: def set(x: T) { current = x }
error: covariant type T occurs in contravariant position in type T of value x def set(x: T) { current = x }
spiegare, si prega di
Oltre alle risposte penetranti, perché avete bisogno il riferimento esplicito e privato getter/setter? Scala fa questo per te: 'classe Cella [+ T] (val t: T) {...}' –