alexey_rom: (Default)
alexey_rom ([personal profile] alexey_rom) wrote2010-03-11 02:57 pm

Откровения Guido van Rossum о функциональных языках

Цитата из Masterminds of Programming:
Python probably has the reputation of supporting functional programming based on the inclusion of lambda, map, filter and reduce in the language, but in my eyes these are just syntactic sugar, and not the fundamental building blocks that they are in functional languages. The more fundamental property that Python shares with Lisp (not a functional language either!) is that functions are first-class objects, and can be passed around like any other object. This, combined with nested scopes and a generally Lisp-like approach to function state, makes it possible to easily implement concepts that superficially resemble concepts from functional languages, like currying, map, and reduce. The primitive operators that are necessary to implement those concepts are built into Python, where in functional languages, those concepts are the primitive operations. You can write reduce() in a few lines of Python. Not so in a functional language.

Перевод:
Считается, что Python поддерживает функциональное программирование, скорее всего из-за включения lambda, map, filter и reduce в язык. Но с моей точки зрения это просто синтаксический сахар, а не основные строительные блоки, которыми они являются в функциональных языках. Куда более фундаментальным свойством, общим для Python и Lisp (который тоже не функциональный язык!), является то, что функции — объекты первого класса, и могут передаваться так же, как и любой другой объект. Это, в сочетании с вложенными областями видимости и в общем близким к Lisp'у подходом к состоянию функций, позволяет легко реализовать возможности, поверхностно напоминающие о таких возможностях функциональных языков, как карринг, map, и reduce. В Python встроены примитивные конструкции, необходимые для реализации этих понятий; а вот в функциональных языках они сами и являются примитивными конструкциями. В Python достаточно нескольких строк, чтобы написать reduce(). В функциональных языках это не так.

[identity profile] rmihael.livejournal.com 2010-03-11 12:07 pm (UTC)(link)
"В Python достаточно нескольких строк, чтобы написать reduce(). В функциональных языках это невозможно".
Он что, прикалывается?

[identity profile] sdfgh153.livejournal.com 2010-03-11 12:39 pm (UTC)(link)
Ну я всегда подозревал, что от него ничего хорошего не дождешься.

[identity profile] archimag-dev.blogspot.com (from livejournal.com) 2010-03-11 01:05 pm (UTC)(link)
О, отлично, теперь буду на него ссылаться, доказывая неверующим, что Common Lisp не является функциональным языком ;)

[identity profile] ivan-gandhi.livejournal.com 2010-03-11 01:50 pm (UTC)(link)
Он сделал свой язык, вполне компактный, юзабельный, и, при определённой сноровке, пригодный на вполне хорошие проекты. Но будущего нет ни у Питона, ни у Гвидо. Спросите его про монаду. Он не знает и не хочет знать про монаду. Ну и т.д. Так что язык, как бы он ни был хорош, останется набором хороших штучек, соответствующих передовым понятиям примерно 2000-го года.

[identity profile] zevlg.livejournal.com 2010-03-11 01:52 pm (UTC)(link)
всё нормально старикан сказал. Я вон для geo задачи (с fprog.ru) накатал парсер файлов с полигонами в три строчки! на питоне - сомневаюсь, что такое возможно на любом ФП:
def contours(f):
    def notEND(): return takewhile(lambda x: x[:3] != "END", f)
    def contour(): return [map(float, l.split()) for l in notEND()]       
    return [(contour(), l[0] == "!") for l in notEND()]

[identity profile] b-al-u.livejournal.com 2010-03-11 02:13 pm (UTC)(link)
Но нельзя в несколькострок сделть лямбду :)

[identity profile] ulysses4ever.livejournal.com 2010-03-11 05:06 pm (UTC)(link)
> В Python встроены примитивные конструкции, необходимые для реализации этих понятий; а вот в функциональных языках они сами и являются примитивными конструкциями. В Python достаточно нескольких строк, чтобы написать reduce(). В функциональных языках это не так.
Одному мне кажется, что в первом предложении он утверждает, что Пайтон более низкоуровневый, чем «функциональные языки», а во вторых двух — что он более высокоуровневый — сиречь противоречит себе?

[identity profile] ivan-gandhi.livejournal.com 2010-04-07 01:23 am (UTC)(link)
Гвидо хороший человек, но образования у него не хватает, и это, конечно, ставит крест на будущем питона.