Існує кілька способів побудови незмінного списку в Scala (див. Надуманий приклад коду нижче). Ви можете використовувати змінний ListBuffer, створити var
список та змінити його, використовувати хвостовий рекурсивний метод та, ймовірно, інші, про які я не знаю.
Інстинктивно я використовую ListBuffer, але у мене немає вагомих причин для цього. Чи є кращий або ідіоматичний метод створення списку, чи існують ситуації, які найкраще підходять для одного методу над іншим?
import scala.collection.mutable.ListBuffer
// THESE are all the same as: 0 to 3 toList.
def listTestA() ={
var list:List[Int] = Nil
for(i <- 0 to 3)
list = list ::: List(i)
list
}
def listTestB() ={
val list = new ListBuffer[Int]()
for (i <- 0 to 3)
list += i
list.toList
}
def listTestC() ={
def _add(l:List[Int], i:Int):List[Int] = i match {
case 3 => l ::: List(3)
case _ => _add(l ::: List(i), i +1)
}
_add(Nil, 0)
}
What you DON'T do is use a List and append to it
Це тому, що створюється новий список ? В той час, як використання операції попередньої подачі не створить новий список?