Парадигма | Многопарадигма : императив, функциональные, распределенные, параллельные |
---|---|
Разработано | Саарландским университетом |
Впервые появилось | 2000; 20 лет назад (2000 г.) |
Стабильный выпуск | 1.4 / 3 мая 2007 г.; 13 лет назад (2007-05-03) |
Дисциплина набора текста | сильная, статическая, предполагаемая |
OS | Межплатформенная |
Лицензия | MIT |
Веб-сайт | www.ps.uni-saarland.de / alice |
Под влиянием | |
ML, Oz |
Алисы ML - это язык программирования разработан Лабораторией систем программирования Саарландского университета, Саарбрюккен, Германия. Это диалект из Standard ML, дополненный поддержкой ленивого вычисления, параллелизма (многопоточность и распределенные вычисления через вызовы удаленных процедур ) и программирование в ограничениях.
Алиса расширяет Standard ML несколькими способами, которые отличает его от его предшественника. Алиса предоставляет функции параллелизма как часть базового языка за счет использования типа future, который представляет значение, предоставляемое независимым потоком выполнения. Поток, который использует будущее значение, будет блокироваться при попытке доступа к значению до тех пор, пока выполняющий его поток не завершит вычисление. Также предоставляется связанная концепция, называемая обещанием, позволяющая потоку предоставлять будущее значение, которое он будет вычислять другому потоку. Переменные типа Future и Promise используются для реализации синхронизации потока данных.
Подобно функциональному языку Haskell, Алиса предоставляет средства, позволяющие использовать стратегию ленивого вычисления в программах, в отличие от традиционной стратегии нетерпеливого вычисления стандарта Standard ML. В то время как Haskell по умолчанию использует ленивую модель, Алиса по умолчанию использует модель нетерпеливого вычисления, требуя явного программного оператора для ленивого вычисления вычисления.
Реализация Алисы из Саарландского университета использует простую расширяемую абстрактную машину (SEAM) виртуальную машину. Это бесплатное программное обеспечение, которое включает своевременную компиляцию в байт-код и собственный код для архитектуры x86.
Ранние версии Алисы работали на виртуальной машине (ВМ) Системы программирования Моцарта (Oz), что позволяло взаимодействовать между Алисой и кодом Oz.
Удаленный вызов процедуры Алисы зависит от виртуальной машины, потому что она может отправлять код для вычисления с одного компьютера на другой.
Алиса расширяет Standard ML несколькими примитивами для отложенного вычисления и параллелизма. Например, потоки могут быть созданы с использованием ключевого слова spawn
. Рассмотрим наивный алгоритм вычисления чисел Фибоначчи :
fun fib 0 = 0 | fib 1 = 1 | фиб п = фиб (п-1) + фиб (п-2);
Для больших значений n
, fib n
потребуется много времени для вычисления. Это вычисление может быть выполнено в отдельном потоке с помощью
val x = spawn fib n;
Переменная x
теперь привязана к так называемому будущему. Когда для операции требуется значение x
, она блокируется, пока поток не завершит вычисление. Чтобы использовать параллелизм, можно даже определить fib следующим образом:
fun fib 0 = 0 | fib 1 = 1 | fib n = создать fib (n-1) + fib (n-2);