I-Code haben:Fehler bei Definition kovarianten und kontra Typen
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)
aber ich habe Fehler in Zeile: 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 }
Erklären Sie bitte
Zusätzlich zu den aufschlussreichen Antworten, warum brauchen Sie die explizite private Referenz und Getter/Setter? Scala macht das für dich: 'class Cell [+ T] (val t: T) {...}' –