В информатике, чисто функциональное программирование обычно обозначает парадигму программирования - стиль построения структура и элементы компьютерных программ - все вычисления рассматриваются как вычисления математических функций. Чисто функциональное программирование также может быть определено путем запрета изменений состояния и изменяемых данных.
Чисто функциональное программирование заключается в обеспечении того, чтобы функции в рамках функциональной парадигмы зависели только от своих аргументов, независимо от какого-либо глобального или локального состояния.
Точное различие между чистым и нечистым функциональным программированием является предметом споров.
A Программа обычно считается функциональной, если в ней используются некоторые концепции функционального программирования, такие как функции первого класса и функции высшего порядка. Однако первоклассная функция не обязательно должна быть чисто функциональной, так как она может использовать методы из императивной парадигмы, такие как массивы или методы ввода / вывода , которые не являются чисто функциональными программами. Фактически, самые ранние языки программирования, упомянутые как функциональные, IPL и Lisp, оба были «нечистыми» функциональными языками по текущему определению.
Чисто функциональные структуры данных являются постоянными. Для функционального программирования требуется постоянство; без него одно и то же вычисление могло бы вернуть разные результаты. Функциональное программирование может использовать постоянные не чисто функциональные структуры данных, в то время как эти структуры данных не могут использоваться в чисто функциональных программах.
Каждая стратегия оценки, которая завершается чисто функциональной программой, возвращает тот же результат. В частности, это гарантирует, что программисту не нужно учитывать, в каком порядке оцениваются программы, поскольку нетерпеливое вычисление вернет тот же результат, что и ленивое вычисление. Однако по-прежнему возможно, что нетерпеливое вычисление не завершится, пока ленивое вычисление той же программы останавливается. Преимущество этого состоит в том, что ленивое вычисление может быть реализовано намного проще; поскольку все выражения будут возвращать один и тот же результат в любой момент (независимо от состояния программы), их вычисление может быть отложено на сколько угодно времени.
Чисто функциональное программирование упрощает параллельные вычисления, поскольку две чисто функциональные части оценки никогда не взаимодействуют.
Чисто функциональные структуры данных часто представлены иначе, чем их императивные аналоги. Например, массив с постоянным доступом и обновлением является базовым компонентом большинства императивных языков и многих императивных структур данных, таких как хэш-таблица и двоичная куча, основаны на массивах. Массивы можно заменить на map или, что допускает чисто функциональную реализацию, но время доступа и обновления - логарифмическое. Следовательно, чисто функциональные структуры данных могут использоваться в языках, которые не являются функциональными, но они могут быть не самым эффективным доступным инструментом, особенно если постоянство не требуется.
В общем, преобразование императивной программы в чисто функциональную также требует обеспечения того, чтобы ранее изменяемые структуры теперь явно возвращались функциями, которые их обновляют, программная структура, называемая стилем передачи из хранилища.
Чисто функциональный язык - это язык, допускающий только чисто функциональное программирование. Однако чисто функциональные программы могут быть написаны на языках, которые не являются чисто функциональными.