Par exemple, pourquoi
val list:List[Any] = List[Int](1,2,3)
travailler, mais
val arr:Array[Any] = Array[Int](1,2,3)
échoue (car les tableaux sont invariants). Quel est l'effet souhaité derrière cette décision de conception?
Par exemple, pourquoi
val list:List[Any] = List[Int](1,2,3)
travailler, mais
val arr:Array[Any] = Array[Int](1,2,3)
échoue (car les tableaux sont invariants). Quel est l'effet souhaité derrière cette décision de conception?
Sinon, cela briserait la sécurité de type. Sinon, vous pourriez faire quelque chose comme ceci:
val arr:Array[Int] = Array[Int](1,2,3)
val arr2:Array[Any] = arr
arr2(0) = 2.54
et le compilateur ne peut pas l'attraper.
En revanche, les listes sont immuables, vous ne pouvez donc pas ajouter quelque chose qui n'est pas Int
Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.