Конспект лекций «Методы построения компиляторов» — различия между версиями
Admin (обсуждение | вклад) (→Нисходящий анализ) |
Admin (обсуждение | вклад) (→Восходящий синтаксический анализ) |
||
Строка 88: | Строка 88: | ||
Допуск (accept) | Допуск (accept) | ||
Ошибка (error) | Ошибка (error) | ||
+ | |||
+ | Утв. Основа всегда находится на вершине стека и никогда - внутри него. | ||
+ | Доказательство. | ||
+ | |||
+ | Понятие активного префикса. | ||
+ | |||
+ | LR-анализаторы. SLR, канонический LR и LALR анализаторы. | ||
+ | |||
+ | Общая схема и алгоритм LR-анализа. Пример. | ||
+ | |||
+ | LR-грамматики. | ||
+ | |||
+ | Неоднозначности вида shift-reduce и их разрешение. |
Версия 14:52, 4 января 2009
Содержание
Контекстно свободные грамматики
Определение. Терминалы, нетерминалы, символы. Продукции. Стартовый символ.
Обозначения
a,b,c, ... - терминалы u,v,w,x,y,z - строки терминалов A,B,C, ... - нетерминалы α,β,γ, ... - строки нетерминалов
Пример. Грамматика арифметических выражений.
E → E+E | E*E | (E) | -E | id
Порождение (вывод)
Обозначения
=> =>* =>+
Опр. Сентенциальной формой (цепочкой) грамматики называется строка, которая может быть выведена из стартового символа.
Опр. Предложением грамматики называется сентенциальная форма, состоящая из одних терминалов.
Опр. Языком L(G) грамматики G называется множество всех ее предложений.
Левое, правое порождение. Примеры.
Обозначения
=>(lm) =>(lm)* =>(rm)+
Дерево разбора строки грамматики. В отличие от порождения, из него исключена информация о порядке вывода.
Грамматика, которая дает более одного дерева разбора для некоторого предложения, называется неоднозначной.
Пример неоднозначной грамматики.
stmt → if expr then stmt | if expr then stmt else stmt | other
Леворекурсивные грамматики, их проблемы. Алгоритм устранения левой рекурсии.
Синтаксический анализ
Понятие синтаксического анализатора.
Нисходящие (top-down) и восходящие (bottom-up) синтаксические анализаторы
Нисходящий синтаксический анализ
Опр. Синтаксический анализатор, работающий методом рекурсивного спуска и не требующий откатов, называется предиктивным синтаксическим анализатором.
Нерекурсивный предиктивный анализ
Схема работы со стеком, таблицей разбора, входным буфером
Алгоритм нерекурсивного предиктивного анализа
Пример
Множества FIRST и FOLLOW
Пример
Алгоритм построения таблиц предиктивного анализа
Определение LL(1) грамматики. Пояснение названия.
Утв. LL(1) грамматика не может быть лворекурсивной или неоднозначной.
Эквивалентное определение LL(1) грамматики.
Восстановление после ошибок в предиктивном анализе
Восходящий синтаксический анализ
Наиболее распространенная разновидность - ПС-анализ (перенос-свертка - shift-reduce)
Понятие основы. Примеры.
Обращенное правое порождение и обрезка основ.
Стековая реализация ПС-анализа. Основные операции:
Перенос (shift) Свертка (reduce) Допуск (accept) Ошибка (error)
Утв. Основа всегда находится на вершине стека и никогда - внутри него. Доказательство.
Понятие активного префикса.
LR-анализаторы. SLR, канонический LR и LALR анализаторы.
Общая схема и алгоритм LR-анализа. Пример.
LR-грамматики.
Неоднозначности вида shift-reduce и их разрешение.