Scala (język programowania)
Scala – język programowania łączący cechy języków funkcyjnych i obiektowych. Scala działa na Wirtualnej Maszynie Javy, a także na Java Platform, Micro Edition Connected Limited Device Configuration i platformie .NET. Nazwa ma za zadanie podkreślać skalowalność języka, stąd Scala (z ang. scalable language).
Logo języka | |
Pojawienie się |
2003 |
---|---|
Paradygmat |
funkcyjny, obiektowy |
Aktualna wersja stabilna |
3.0.2 (1 września 2021; ponad 3 lata temu[1]) |
Twórca |
Martin Odersky |
Licencja | |
Strona internetowa |
Scala została stworzona w 2001 roku na Politechnice Federalnej w Lozannie przez Martina Odersky'ego. Język ten został upubliczniony w styczniu 2004 roku na platformie Javy, a w czerwcu tego samego roku na platformie .NET. Wersja druga została udostępniona w marcu 2006 roku.
Wspierane paradygmaty
edytujScala wspiera programowanie funkcyjne. Składnia pozwala zwięźle definiować funkcje anonimowe, obsługuje funkcje wyższego rzędu, zagnieżdżanie funkcji i currying. Użycie słowa kluczowego lazy opóźnia przypisanie wartości do chwili, gdy wartość ta będzie potrzebna. W języku Scala większość konstrukcji językowych definiuje wyrażenia (posiadające wartość). Scala pozwala definiować wyrażenia przy pomocy słów kluczowych def, var oraz val. Słowo def pozwala na zdefiniowanie wyrażenia, którego wartość będzie wyliczana zawsze w chwili odwołania się do tego wyrażenia (np. def doubleMe(x: Int) = x * 2
). Przy pomocy słowa var można zdefiniować wyrażenie, którego wartość może podlegać zmianom (ang. mutable - np. var x = 2; x = 4
). Słowo kluczowe val pozwala zdefiniować wartości, które nie podlegają zmianom (ang. immutable). Również takie konstrukcje jak if else, match/case, czy for/yield są wyrażeniami.
Scala ma "klasy przypadków" oraz wbudowane wsparcie dla dopasowywania wzorców. Pozwala to korzystać z algebraicznych typów danych, używanych w wielu funkcyjnych językach programowania. Język ten w umiejętny sposób łączy cechy języka obiektowego (klasy, dziedziczenie, polimorfizm, ...) z cechami języka funkcjonalnego (funkcje wyższego rzędu, liczne kolekcje niemodyfikowalne, currying, dopasowanie wzorców, ...). Oba paradygmaty są równie mocno wspierane.
Rekurencja ogonowa nie jest całkowicie obsługiwana, ponieważ maszyna wirtualna Javy nie udostępnia takiej możliwości. W prostych przypadkach kompilator Scali może optymalizować rekurencję ogonową do postaci pętli.
Implementacja prostego algorytmu sortującego (podobnego do quicksort) w podejściu programowania funkcyjnego może wyglądać następująco:
def qsort(list : List[Int]): List[Int] = list match {
case Nil => Nil
case pivot :: tail => {
val (smaller, rest) = tail partition (_ < pivot)
qsort(smaller) ::: pivot :: qsort(rest)
}
}
Przykłady
edytuj"Hello World"
edytujProgram "Hello World" napisany w Scali ma następującą postać:
object HelloWorld {
def main(args: Array[String]): Unit = {
println("Hello, world!")
}
}
Wybrane rozwiązania napisane w Scali
edytujPrzypisy
edytuj- ↑ Release Scala 3.0.2 · scala/scala · GitHub. GitHub, 2021-09-01. [dostęp 2021-11-03]. (ang.).
Linki zewnętrzne
edytuj- Strona oficjalna (ang.)