монады в функциональном программировании


E-Book Content

Монады в функциональном программировании Филипп Уодлер, Университет Глазго? Отдел Информационных Технологий, Университет Глазго, G12 8QQ, Шотландия ([email protected]) Резюме. Описывается использование монад для структурирования функциональных программ. Монады обеспечивают удобную рабочую среду для моделирования эффектов, найденных в других языках, таких как глобальное состояние, обработка исключений, продукции, или недетерминизм. Подробно рассмотрены три исследования: как монады упрощают модификацию простого вычислителя; как монады действуют в качестве базиса типа данных массивов, подчиненных оперативному обновлению; и как монады могут использоваться, чтобы строить анализаторы. 1 Введение. Буду ли я чист или нечист? Функциональное программное сообщество делится на два лагеря. Чистые языки, такие как Miranda0 и Haskell, являются лямбда-исчислением, чистым и простым. Нечистые языки, такие как Scheme и Standard ML (Стандартный Стакан), увеличивают лямбда-исчисление с рядом возможных эффектов, таких как назначения, исключения, или продолжения. Чистые языки проще в относительных рассуждениях и могут извлечь выгоду из ленивой оценки, в то время как нечистые языки предлагают выгоды эффективности и иногда делают возможным более компактный способ выражения. Недавний прогресс в теоретической вычислительной науке, особенно в областях теории типа и теории категории, предложил новые подходы, которые могут объединить выгоды чистых и нечистых школ. Эти заметки описывают один из них - использование монад, чтобы внести нечистые эффекты в чистые функциональные языки. Понятие монады, которая является результатом теории категории, было применено Moggi, чтобы структурировать деописательную семантику языков программирования [13, 14]. Та же самая техника может быть применена, чтобы структурировать функциональные программы [21, 23]. Приложения монад будут иллюстрированы тремя исследованиями. Секция 2 вводит монады, показывая, как они могут использоваться для структурирования простого вычислителя с учётом облегчения дальнейших изменений. Секция 3 описывает законы, удовлетворенные ? Появляется в: J. Jeuring и E. Meijer, редакторы, Передовое Функциональное Программирование (Advanced Functional Programming), Слушания Весенней школы B*astad, в мае 1995, Springer Verlag Лекционные Заметки в Computer Science 925. Предыдущая версия этой заметки появилась в: M. Broy, редактор, Исчисления Проекта Программы (Program Design Calculi), Слушания Летней Школы Marktoberdorf, 30 июля - 8 августа 1992. Некоторые опечатки исправлены в августе 2001; благодарность Дэну Фридману за их обнаружение. 0 Miranda - торговая марка Research Software Limited (Ограниченного Программного обеспечения Исследования). монадами. Секция 4 показывает, как монады обеспечивают новое решение старой проблемы обеспечения обновляемого состояния в чистых функциональных языках. Секция 5 применяет монады к проблеме построения рекурсивных анализаторов спуска; это представляет интерес в его собственном праве, потому что это обеспечивает парадигму для последовательного выполнения операций и чередования, двух из центральных концепций вычисления. Сомнительно, что методы структурирования, представленные здесь были бы обнаружены без понимания, предоставленного в соответствии с теорией категории. Но когда-то обнаруженные они легко выражены без какой-либо ссылки на категориальные «вещи». Никакое знание теории категорий не обязательно для чтения этих заметок. Примеры будут даваться на Haskell, но никакое его знание также не потребуется. То, что требуется, - мимолетные дружественные отношения с основами чистого и нечистого функционального программирования; для общего развития см. [3, 12]. Языки для ссылок Haskell [4], Miranda [20], Standard ML [11], и Scheme [17]. 2 Вычисление монад. Чистые функц
You might also like

Functional Programming
Authors: Fokker J.    180    0


Shape Analysis And Structuring
Authors: Leila de Floriani , Michela Spagnuolo    143    0


Digital Image Processing (preview)
Authors: Rafael C. Gonzalez , Richard E. Woods    162    0



Algorithms
Authors: Sanjoy Dasgupta , Christos Papadimitriou , Umesh Vazirani    193    0


Professional Programmer's Guide To Fortran 77
Authors: Page C    139    0


Combinatorial Optimization: Networks And Matroids
Authors: Lawler E.L.    162    0


System Theory, The Schur Algorithm And Multidimensional Analysis
Authors: Daniel Alpay , Victor Vinnikov    210    0



Tex, Xml, And Digital Typography: International Conference On Tex, Xml, And Digital Typography, Held Jointly With The 25th Annual Meeting Of The Tex Users Group, Tug 2004, Xanthi, Greece, August 30 - September 3, 2004. Proceedings
Authors: Christos K. K. Loverdos , Apostolos Syropoulos (auth.) , Apostolos Syropoulos , Karl Berry , Yannis Haralambous , Baden Hughes , Steven Peter , John Plaice (eds.)    106    0