Цикл чтения-вычисления-печати ( REPL ), также называемый интерактивной оболочкой верхнего уровня или языковой оболочкой , представляет собой простую интерактивную среду программирования компьютера , которая принимает отдельные входные данные пользователя, выполняет их и возвращает результат пользователю; программа, написанная в среде REPL, выполняется по частям. [1] Термин обычно относится к программным интерфейсам, похожим на классическую интерактивную среду машины Lisp . Распространенными примерами являются оболочки командной строки и аналогичные среды для языков программирования , а эта техника очень характерна для языков сценариев . [2]
В 1964 году выражение цикл READ-EVAL-PRINT было использовано Л. Питером Дойчем и Эдмундом Беркли для реализации Lisp на PDP-1 . [3] Всего месяц спустя Project Mac опубликовал отчет Джозефа Вайценбаума (создателя ELIZA , первого в мире чат-бота), описывающий язык на основе REPL, названный OPL-1, реализованный на его языке Fortran-SLIP на совместимой системе разделения времени (CTSS) . [4] [5] [6]
В справочном руководстве Maclisp 1974 года Дэвида А. Муна на странице 89 упоминается «цикл чтения-оценки-печати», но аббревиатура REPL не используется. [7]
По крайней мере с 1980-х годов аббревиатуры REP Loop и REPL засвидетельствованы в контексте Схемы . [8] [9]
В REPL пользователь вводит одно или несколько выражений (а не целый блок компиляции ), а REPL оценивает их и отображает результаты. [1] Название цикла read–eval–print происходит от названий примитивных функций Lisp, которые реализуют эту функциональность:
(+ 1 2 3)
, которое анализируется в связанный список, содержащий четыре элемента данных.+
вызывается для аргументов 1 2 3
, возвращая результат 6
.Затем среда разработки возвращается в состояние чтения, создавая цикл, который завершается при закрытии программы.
REPL облегчают исследовательское программирование и отладку , поскольку программист может проверить напечатанный результат, прежде чем решить, какое выражение предоставить для следующего чтения. Цикл чтение-вычисление-печать вовлекает программиста чаще, чем классический цикл редактирование-компиляция-запуск-отладка.
Поскольку функция print выводит данные в том же текстовом формате, который функция read использует для ввода, большинство результатов выводится в форме, которую можно скопировать и вставить обратно в REPL. Однако иногда необходимо вывести представления элементов, которые не могут быть разумно прочитаны обратно, например, дескриптор сокета или сложный экземпляр класса. В этих случаях должен существовать синтаксис для нечитаемых объектов. В Python это нотация <__module__.class instance>
, а в Common Lisp — #<whatever>
форма. REPL CLIM , SLIME и Symbolics Lisp Machine также могут считывать нечитаемые объекты. Они записывают для каждого вывода, какой объект был напечатан. Позже, когда код будет считан обратно, объект будет извлечен из напечатанного вывода.
REPL могут быть созданы для поддержки любого текстового языка. Поддержка REPL для компилируемых языков обычно достигается путем реализации интерпретатора поверх виртуальной машины, которая предоставляет интерфейс для компилятора. Например, начиная с JDK 9, Java включила JShell в качестве интерфейса командной строки для языка. Различные другие языки имеют сторонние инструменты, доступные для загрузки, которые обеспечивают аналогичное взаимодействие оболочки с языком.
Как оболочка , среда REPL позволяет пользователям получать доступ к соответствующим функциям операционной системы в дополнение к предоставлению доступа к возможностям программирования. Наиболее распространенное использование REPL вне оболочек операционной системы — интерактивное прототипирование . [10] Другие области применения включают математические вычисления, создание документов, интегрирующих научный анализ (например, IPython ), интерактивное обслуживание программного обеспечения, бенчмаркинг и исследование алгоритмов.
Минимальное определение:
( определить ( REPL env ) ( распечатать ( eval env ( прочитать ))) ( REPL env ) )
где env
представляет начальную eval
среду -uation. Также предполагается, что env
может быть деструктивно обновлено eval
.
Типичные функциональные возможности, предоставляемые Lisp REPL, включают:
*
ссылается на последний результат **
и ***
на результаты до него.Центральным компонентом интерпретатора Scheme является цикл read-eval-print . Команды считываются, затем оцениваются. Наконец, распечатывается оцененный результат.
{{cite book}}
: CS1 maint: постскриптум ( ссылка )