Icon (язык программирования)
Icon — язык программирования, унаследовавший идеологию более раннего языка того же автора Снобол. Название языка не имеет ничего общего с «иконками», а является сокращением от слова англ. iconoclastic (иконоборческий), используемом в смысле борьбы с конформизмом в разработке языков программирования. Это сверхвысокоуровневый язык программирования, в который интегрированы механизмы сопоставления с образцом и бэктрекинга, что сближает его с языками логического программирования. Язык является динамически типизированным, имеет встроенные мощные типы данных. Процедуры в Icon’е относятся к величинам первого класса (англ. first class values), что означает возможность присваивания переменным значений самих процедур, а не результатов их выполнения. Существует механизм совыражений (англ. co-expression), позволяющий создавать сопрограммы. Базовый синтаксисСинтаксис Icon унаследован у семейства языков программирования Algol и напоминает синтаксис языков C или Pascal. На Паскаль Icon похож больше, он использует для присваивания знак Процедуры — основной строительный блок Icon-программ, однако, в отличие от процедур в Паскале, они (подобно функциям Си и Паскаля) могут возвращать значения; ключевого слова
Целенаправленное выполнениеЛюбое предложение (оператор) языка Icon на самом деле является выражением и может возвращать значения. Выражения в Icon, помимо собственно возвращаемых ими значений, которых может быть любое количество, производит одно из двух состояний — успех англ. success или неудачу англ. failure. Успех или неудача выражений используются вместо булевых значений управляющими структурами Icon. Благодаря этому мы можем писать конструкции типа:
Более того, поскольку состояние «неудачи» имеет свойство «всплывать» из вложенных вызовов функций, становясь результатом внешней функции, можно использовать ещё более краткие идиомы, вроде:
для чтения потока ввода и дублирования его в поток вывода (echo). Операции сравнения, такие Связанная с успехом и неудачей концепция называется в Icon целенаправленным выполнением англ. goal-directed execution. Это способ, благодаря которому вычисление может продолжаться, пока не будет достигнута некая цель. В вышеприведённом примере с echo цель — чтение всего содержимого файла на входе, пока не будет встречен конец файла. Цель задаётся непосредственно, а не с помощью дополнительных проверок кодов возврата или чего то подобного. Целенаправленное вычисление реализуется с помощью бэктрэкинга, это очень мощный механизм. ГенераторыСерьёзным нововведением языка являются генераторы, обобщающие механизма итераторов[3]. Именно из айкона идея генераторов попала в такие языки, как Python[4]. Thomas W. Christopher, автор Icon Programming Language Handbook пишет: «Самое большое различие между Icon и другими языками программирования — это то, что выражения в Icon — генераторы». Пример использования генератора: procedure main() L:=["1","22","333"] # Список строк every writes(" ",! L) end ---- Выход: 1 22 333 Влияние на последующие языкиЯзыки Icon и Снобол послужили своего рода полигоном для отработки некоторых идиом программирования, особенно это касается конструкций, содержащих Вот пример подобной идиомы: [ $ringing != 0 ]&&echo Phone ringing!!! Другой пример, пусть есть конструкция в shell: xview -root `gtk-shell -t "Which image?" -fs`
Даже если вы не выберете имя файла-картинки, xview все равно будет запущен. А в языке Icon этого никогда бы не произошло. Аналоги регулярных выражений являются частью самого языка, позволяя использовать системы обработки текста неограниченной сложности. Гибкость языка позволяет записывать очень большое количество действий, не уменьшая при этом удобочитаемость текста. Реализация и диалектыАвторская реализация Icon, написанная в Аризонском Университете (т. н. аризонский icon) распространяется в соответствии с лицензией GNU GPL. Icon 9.3 (последняя версия имеющая нативную поддержку Windows) была реализована как компилятор в байт-код с генерацией исполняемого файла содержащего интерпретатор этого байт-кода. Начиная с версии 9.4 аризонский Icon реализован как классический скриптовый язык Unix. После смерти автора языка, разработка классического аризонского айкона долгое время была заморожена, предпоследняя версия Icon v.9.4.3 была выпущена 14 ноября 2005, однако в настоящее время его поддержка возобновлена его учеником Грегом Таунсендом. 12 апреля 2010 выпущена новая версия транслятора. Активно развивающейся ветвью Icon является язык Unicon[англ.], транслятор которого основан на его коде, и также распространяемый под лицензией GNU GPL. Это объектно-ориентированный диалект языка, с улучшенной интеграцией с окружающей средой ОС, включая, к примеру, поддержку взаимодействия с БД. Подобно icon v.9.3, Unicon — это транслятор, ориентированный на генерацию исполняемых файлов. Продолжает развиваться диалект ObjectIcon, базирующийся на ранних версиях Unicon и являющийся форком последнего. ObjectIcon, как следует из названия, является расширенной объектно-ориентированной версией Icon, в частности, в отличие Unicon, в ObjectIcon есть модификаторы полей доступа к методам. В ObjectIcon сильно изменён состав библиотек (большая часть IPL была сильно переработана — некоторые модули были удалены, были полностью изменены графические библиотеки.), добавлена поддержка Unicode, поддержка пространств имён, добавлены множественное наследование и автоматическая инициализация констант и переменных — и теперь это современный и мощный ООП-язык. Разрабатывается Робертом Парлеттом и распространяется по MIT лицензии. Доступен к загрузке на SourceForge, работает в среде Linux/Unix. Языки-потомкиLaurence Tratt, один из разработчиков Icon 9.5 и ObjectIcon, также является автором спроектированного по похожим принципам языка Converge[5]. В 2015 году Грегом Таунсенд представил язык Goaldi (от Goal Direction). Это объектно-ориентированный язык, реализованный на Go, и унаследовавший многие черты Icon. В нём реализованы замыкания, параллельное программирование, поддержка пространств имён и работа с юникодом. При этом в нём отсутствуют такие черты айкона, как сканирование строк в качестве базовой операции языка (взамен используется сравнение с обычными регулярными выражениями на уровне функций) и связанные с ней такие типы данных, как множество символов, остсутствует арифметика произвольной точности, а ошибки не преобразуются в обрабатываемые бэктрекингом неудачи, но обрабатываются механизмом исключений[6]. Литература
Примечания
Ссылки
Диалекты и дистрибутивы
|
Portal di Ensiklopedia Dunia