В Java я мог бы сделать это:
class MyClass {
private List<? extends MyInterface> list;
public void setList(List<MyImpl> l) { list = l; }
}
... при условии, что (MyImpl implements MyInterface
) конечно.
Что является аналогом для этого в Scala , когда используется Buffer
?
import java.lang.reflect._
import scala.collection.mutable._
class ScalaClass {
val list:Buffer[MyInterface] = null
def setList(l: Buffer[MyImpl]) = {
list = l
}
}
Это (конечно) не компилируется - но как мне объявить переменную list
таким образом, что она делает?
EDIT ; Я добавляю немного больше. Разница, очевидно, связана с тем, что в Java генерики никогда не ковариантны в T , тогда как в Scala они могут быть либо ковариантными, либо нет. Например, класс Scala List
является ковариантным по T (и обязательно неизменным). Поэтому следующее скомпилирует :
class ScalaClass {
val list:List[MyInterface] = null
def setList(l: List[MyImpl]) = {
list = l
}
}
Я все еще немного борюсь с ошибкой компилятора:
Covariant type T occurs in contravariant position in ...
Например; эта ошибка компилятора возникает в объявлении класса:
class Wibble[+T] {
var some: T = _ //COMPILER ERROR HERE!
}
Я собираюсь задать отдельный вопрос ...