whileb ≠ 0. ifa>b. a: = a - b. else. b: = b - a. returna
В информатике, абстрактное синтаксическое дерево(AST) или просто синтаксическое дерево, представляет собой дерево представление абстрактного синтаксическая структура исходного кода, написанная на языке программирования. Каждый узел дерева обозначает конструкцию, встречающуюся в исходном коде.
Синтаксис является «абстрактным» в том смысле, что он представляет не все детали, встречающиеся в реальном синтаксисе, а скорее только структурные или связанные с содержанием детали. Например, группирование круглых скобок неявно присутствует в древовидной структуре, поэтому их не нужно представлять как отдельные узлы. Точно так же синтаксическая конструкция, такая как выражение «если-условие-то», может быть обозначена посредством единственного узла с тремя ветвями.
Это отличает абстрактные синтаксические деревья от конкретных синтаксических деревьев, традиционно называемых деревьями синтаксического анализа. Деревья синтаксического анализа обычно строятся парсером во время преобразования исходного кода и компиляции. После построения дополнительная информация добавляется к AST посредством последующей обработки, например, контекстный анализ.
Абстрактные синтаксические деревья также используются в программном анализе и программном преобразовании системы.
Абстрактные синтаксические деревья - это структуры данных, широко используемые в компиляторах для представления структуры программного кода. AST обычно является результатом фазы синтаксического анализа компилятора. Он часто служит промежуточным представлением программы на нескольких этапах, которые требуются компилятору, и оказывает сильное влияние на конечный результат компилятора.
AST имеет несколько свойств, которые помогают на дальнейших этапах процесса компиляции:
AST необходимы из-за неотъемлемой природы языков программирования и их документации. Языки часто неоднозначны по своей природе. Чтобы избежать этой двусмысленности, языки программирования часто указываются как контекстно-свободная грамматика (CFG). Однако часто есть аспекты языков программирования, которые CFG не могут выразить, но являются частью языка и задокументированы в его спецификации. Это детали, которые требуют контекста для определения их достоверности и поведения. Например, если язык позволяет объявлять новые типы, CFG не может предсказать имена таких типов или способ их использования. Даже если в языке есть предопределенный набор типов, для обеспечения правильного использования обычно требуется некоторый контекст. Другой пример - утиный ввод, где тип элемента может меняться в зависимости от контекста. Перегрузка оператора - это еще один случай, когда правильное использование и конечная функция определяются на основе контекста. Java представляет собой отличный пример, в котором оператор «+» является одновременно числовым сложением и объединением строк.
Хотя существуют и другие структуры данных, участвующие во внутренней работе компилятора, AST выполняет уникальную функцию. На первом этапе, этапе синтаксического анализа, компилятор создает дерево синтаксического анализа. Это дерево синтаксического анализа можно использовать для выполнения почти всех функций компилятора с помощью синтаксически-управляемой трансляции. Хотя этот метод может привести к более эффективному компилятору, он противоречит принципам разработки и сопровождения программ. Еще одно преимущество AST перед деревом синтаксического анализа - это размер, особенно меньшая высота AST и меньшее количество элементов.
Дизайн AST часто тесно связан с дизайном компилятора и его ожидаемыми функциями.
Основные требования включают следующее:
Эти требования могут использоваться для проектирования структура данных для AST.
Для некоторых операций всегда требуются два элемента, например два термина для сложения. Однако некоторые языковые конструкции требуют произвольно большого числа дочерних элементов, например списков аргументов, передаваемых программам из командной оболочки . В результате AST, используемый для представления кода, написанного на таком языке, также должен быть достаточно гибким, чтобы можно было быстро добавлять неизвестное количество дочерних элементов.
Для поддержки проверки компилятора должна быть возможность разобрать AST в форме исходного кода. Созданный исходный код должен быть достаточно похож на оригинал по внешнему виду и идентичным по исполнению после перекомпиляции.
AST интенсивно используется во время семантического анализа, когда компилятор проверяет правильность использования элементов программы и языка. Компилятор также генерирует таблицы символов на основе AST во время семантического анализа. Полный обход дерева позволяет проверить правильность программы.
После проверки правильности AST служит основой для генерации кода. AST часто используется для генерации промежуточного представления (IR), иногда называемого промежуточным языком, для генерации кода.
| journal =
(help ) (обзор реализации AST в различных языковых семьях )| journal =
(справка )(прямая ссылка на PDF )На Викискладе есть материалы, связанные с абстрактными синтаксическими деревьями . |