Scala

Матеріал з Вікіпедії — вільної енциклопедії.
Перейти до: навігація, пошук
Scala
Scala logo.png
Парадигма: декілька парадигм: функціональна, об'єктно-орієнтована
Розробник: Мартин Одерски
Останній реліз: 2.12 (29 жовтня 2016; 38 днів тому)
Під впливом від: Java, Pizza, Haskell, Erlang, Standard ML, Objective Caml, Smalltalk
ОС: Багатоплатформова
Ліцензія: Scala License (BSD похідна)
Сторінка інтернет: www.scala-lang.org

Scala — мультипарадигмова мова програмування, що поєднує властивості об'єктно-орієнтованого та функційного програмування. Назва Scala утворена зі слів "scalable" (маштабовна) та "language" (мова), для того щоб задекларувати, що мова може рости разом з вимогами користувачів.

Платформа[ред.ред. код]

Програми мовою Scala виконуються на віртуальній машині Java за умови приєднання до дистрибутиву файлу scala-library.jar. Scala сумісна із існуючими програмами мовою Java, тобто код Scala може викликатися із Java-програм і навпаки. Починаючи з версії 2.11 Scala потребує принаймні Java 6[1], а версія 2.12 потребуватиме Java 8 та матиме кращу інтеграцію із новими можливостями цієї версії Java[2].

У лютому 2015 року після двох років розробки випущено стабільну версію Scala.js — компілятора мови Scala у JavaScript[3].

До версії 2.11 існувала експериментальна реалізація для платформи .NET.[1] Дистрибутив Scala, включно з компілятором і бібліотеками, випущено під BSD-похідною ліцензією.

Мова[ред.ред. код]

Вплив[ред.ред. код]

На Scala вплинуло багато мов[4]. Однорідна об'єктна модель вперше з'явилася у Smalltalk і згодом у Ruby. Універсальність вкладеності присутня у Algol, Simula, Beta. Принцип однорідного доступу для виклику методу і звернення до поля походить з мови Eiffel. Підхід до функціонального програмування подібний до підходу родини мов ML, таких як has SML, OCaml і F#. Багато функцій вищого порядку у стандартній бібліотеці Scala також наявні у ML або Haskell. Неявні параметри у Scala аналогічні класам типів Haskell. Заснована на акторах бібліотека багатозадачності подібна до Erlang.

Змінні[ред.ред. код]

Методи[ред.ред. код]

Починаючи з версії 2.8 Scala підтримує значення аргументів за умовчанням та іменовані аргументи. Методи у Scala можуть бути вкладеними, вкладений метод бачить змінні зовнішнього. Зазвичай параметри до методу передаються за значенням (Call-by-Value) — значення аргументів обчислюється перед викликом методу і передаються до методу. Scala підтримує також передачу параметрів за назвою (Call-by-Name). У цьому разі в метод передається вираз, але обчислюється не під час виклику методу, а під час кожного звернення до нього в тілі методу.

Рівні доступу[ред.ред. код]

За умовчанням рівень доступу до членів класу у Scala є загальнодоступним (public).

Відкриття доступу підкласам (protected), так само як у C++ і C# відкриває доступ лише підкласам, на відміну від Java, в якій protected також отримують доступ усі класи того самого пакету. Члени з видимістю protected доступні у інших екземплярах цього ж класу, але нащадки не мають доступу до protected членів інших екземплярів своїх базових класів (так само як і в Java).

Члени з видимістю private доступні лише у екземплярах цього ж класу. У Java private обмежує доступ на рівні класу найвищого рівня вкладеності, тобто зовнішній клас може одержати доступ до private члена внутрішнього вкладеного класу[5], що не дозволяє Scala.

У Scala protected і private можуть мати кваліфікатор доступу у квадратних дужках: protected[C]. Кваліфікатор доступу члена може бути іменем зовнішнього класу чи пакету, тоді вказаний клас або всі класи, що знаходяться у вказаному пакеті отримують доступ до члена. Також кваліфікатор доступу може бути this, тоді член доступний лише із свого екземпляру, але не доступний через інші екземпляри класу.

Супутні об'єкти (companion objects) мають спільний рівень доступу із своїми супутніми класами.

Історія[ред.ред. код]

Розробка Scala почалася у 2001 році у Федеральній політехнічній школі Лозанни (фр. École polytechnique fédérale de Lausanne, EPFL) Мартином Одерски.[6] Перед цим Одерски створив Generic Java і javac, компілятор мови Java.[6]

  • 2001 — початок розробки як практичнішого спадкоємця Funnel
  • 2003 — перший експериментальний випуск, навчальний курс в університеті
  • 2004 — стаття Scalable Component Abstractions, перша публічна версія
  • 2005 — Scala 2.0, реалізована на Scala (перша версія — на Java), зріла версія
  • 2007 — перший випуск Lift
    • 18 грудня 2007 — доступна рання версія книги Programming in Scala[7]
  • 2008 — Twitter використовує Scala, перша конференція Scala Lift Off
  • 2009 — підтримка IDE, виходять англійською мовою 3 книжки про Scala і одна про Lift
  • 2010 — конференція ScalaDays, виходять 3 книжки японською мовою

17 січня 2011 команда Scala виграла п’ятирічний дослідницький грант на €2.3 мільйонів від Європейської дослідницької ради.[8] 12 травня 2011 Одерски разом із іншими зацікавленими у розвитку Scala заснував Typesafe Inc., компанію для надання комерційної підтримки, навчання і послуг для Scala.

Оцінка[ред.ред. код]

Часто висловлюються думки, що в довгостроковій перспективі Scala може замінити Java[9].

Згідно опитування ZeroTurnAround 2014 року 47% Java-розробників обрали би Scala наступною мовою програмування для JVM [10]. Автор мови Groovy Джеймс Стракен розглядає Scala як заміну Java у довгостроковій перспективі, та стверджує, що якби він свого часу познайомився зі Скалою, то імовірно не створив би Груві[11]. Основний розробник JRuby Чарльз Наттер вважає Scala "наступником трону Java" [12]. Брюс Еккель, автор відомих книжок «Філософія C++» (англ. Thinking in C++) і «Філософія Java» (англ. Thinking in Java), стверджує, що Scala, зберігаючи переваги і статичної типізації, часто відчувається навіть більш лаконічною та ясною ніж мови із динамічною типізацією, такі як Python[13]. Кей Хорстман, відомий як автор книги «Основи Java» (англ. Core Java), вважає Scala найпривабливішим вибором для тих, хто хоче просунутися за межі Java чи С++[14].

У 2014 році мова Scala отримала нагороду «Технологія року» від InfoWorld [15].

Згідно опитування O'Reilly у 2015 році 10% дослідників даних використовують Scala. Значною мірою це пов’язано із популярністю Apache Spark, яким користуються 17% дослідників, із яких 46% використовують одночасно Spark і Scala. Знання цих двох технологій виявилося найзначущим коефіцієнтом пов’язаним із розміром платні, яка в середньому вища на $15000 ніж у аналогічних дослідників, що не володіють ними.[16]

Примітки[ред.ред. код]

  1. а б Scala 2.11.0 is now available!
  2. Scala 2.12 roadmap
  3. Scala.js no longer experimental
  4. Chapter 1 of Programming in Scala, First Edition, A Scalable Language
  5. Java Language Specification: Access Control
  6. а б Martin Odersky, "A Brief History of Scala", Artima.com weblogs, June 9, 2006
  7. Artima Publishes First (e)Book
  8. Scala Team Wins ERC Grant. Процитовано 4 July 2015. 
  9. Roundup: Scala as the long term replacement for Java
  10. Java Tools and Technologies Landscape for 2014
  11. Scala as the long term replacement for java/javac?
  12. The Future: Part One
  13. Scala: The Static Language that Feels Dynamic
  14. Diving into Scala: A Conversation with Java Champion Cay Horstmann
  15. InfoWorld's 2014 Technology of the Year Award winners. InfoWorld. «Привабливе поднання у мові Scala об’єктно-орієнтованих та функційний парадигм програмуваня одержало істотний розиток з часу її появи у 2003 році. Scala продемонструвала можливість мати переваги статичної типізації під час компіляції з дуже потужною системою типів, зберігаючи риси "швидкої розробки програмного забезпечення" і продуктивності, яка зазвичай пов’язується з мовами із динамічною типізацією. Завдяки чудовій підтримці паралельного програмування моделлю акторів та визначним підтримуючим бібліотекам і фреймворкам, таким як Akka і Play, Scala готова бути значним основним гравцем на десятиліття.» 
  16. 2015 Data Science Salary Survey

Література[ред.ред. код]

Посилання[ред.ред. код]