PLAN (1131471)
Текст из файла
4
План-проспект монографии В.А.Серебрякова
“Лекции по конструированию компиляторов”
Предлагаемая вниманию читателя книга основана на курсе лекций, прочитанных автором на факультете вычислительной математики и кибернетики Московского государственного университета в 1991-1993 гг. Автор надеется, что издание книги восполнит существенный пробел в литературе на руссом языке по разработке компиляторов.
Содержание книги представляет собой "классические" разделы предмета: лексический и синтаксический анализ, организация памяти транслятора (таблицы символов) и периода исполнения (магазина), генерация кода, в частности генерация арифметических и логических выражений. Рассматриваются некоторые средства автоматизации процесса разработки трансляторов, такие как LEX, YACC, Супер, методы генерации оптимального кода. Сделана попытка на протяжении всего изложения провести единую "атрибутную" точку зрения на процесс разработки компилятора. В книге не затрагиваются чрезвычайно важные вопросы глобальной оптимизации и разработки компиляторов для машин с параллельной архитектурой. Автор надеется восполнить эти пробелы в будущем.
Книга будет полезной как студентам и аспирантам программистских специальностей, так и профессионалам в этих областях.
Оглавление
Глава 1. Введение
1.1. Место компилятора в программном обеспечении
1.2. Структура компилятора
Глава 2. Лексический анализ
2.1. Регулярные множества и регулярные выражения
2.2. Конечные автоматы
2.3. Построение детерминированного конечного
автомата по недетерминированному
2.4. Построение детерминированного конечного
автомата по регулярному выражению
2.5. Построение детерминированного конечного
автомата с минимальным числом состояний
2.6. Программирование лексических анализаторов
2.7. Конструктор лексических анализаторов LEX
Глава 3. Синтаксический анализ
3.1. Основные понятия и определения
3.2. Таблично-управляемый предсказывающий разбор
3.2.1. Алгоритм разбора сверху-вниз
3.2.2. Множества FIRST и FOLLOW
3.2.3. Конструирование таблиц
предсказывающего анализатора
3.2.4. LL(1)-грамматики
3.2.5. Удаление левой рекурсии
3.2.6. Левая факторизация
3.2.7. Рекурсивный спуск
3.2.8. Диаграммы переходов для рекурсивного спуска
3.2.9. Восстановление после синтаксических ошибок
3.3. Разбор снизу-вверх типа сдвиг-свертка
3.3.1. Основа
3.3.2. LR(k)-анализаторы
3.3.3. LR грамматики
3.3.4. Конфликты разбора типа сдвиг-свертка
3.3.5. Восстановление после синтаксических ошибок
Глава 4. Элементы теории перевода
4.1. Преобразователи с магазинной памятью
4.2. Синтаксически управляемый перевод
4.3. Атрибутные грамматики
4.3.1. Определение атрибутных грамматик
4.3.2. Атрибутированное дерево разбора
4.3.3. Язык описания атрибутных грамматик
4.3.4. Классы атрибутных грамматик и их реализация
Глава 5. Контекстные условия языков программирования
5.1. Описание областей видимости и блочной структуры
5.2. Структура среды Модулы-2
5.3. Занесение в среду и поиск объектов
Глава 6. Организация таблиц символов компилятора
6.1. Таблицы идентификаторов и таблицы символов
6.2. Таблицы идентификаторов
6.3. Таблицы символов и таблицы расстановки
6.4. Функции расстановки
6.5. Таблицы на деревьях
6.6. Реализация блочной структуры
6.7. Сравнение различных методов реализации таблиц
Глава 7. Промежуточные представления программы
7.1. Представление в виде ориентированного графа
7.2. Трехадресный код
7.3. Линеаризованные представления
7.4. Виртуальная машина Java
7.5. Организация информации в генераторе кода
7.6. Уровень промежуточного представления
Глава 8. Генерация кода
8.1. Модель машины
8.2. Динамическая организация памяти
8.2.1. Организация магазина со статической цепочкой
8.2.1. Организация магазина с дисплеем
8.3. Назначение адресов
8.4. Трансляция переменных
8.5. Трансляция целых выражений
8.6. Распределение регистров при вычислении
арифметических выражений
8.7. Трансляция логических выражений
8.8. Выделение общих подвыражений
8.9. Генерация оптимального кода методам
синтаксического анализа
8.9.1. Сопоставление образцов
8.9.2. Синтаксический анализ для Т-грамматик
8.9.3. Выбор дерева вывода наименьшей стоимости
Литература
За последние пять лет книг на русском языке по тематике конструирования компиляторов не публиковалось.
4
Характеристики
Тип файла документ
Документы такого типа открываются такими программами, как Microsoft Office Word на компьютерах Windows, Apple Pages на компьютерах Mac, Open Office - бесплатная альтернатива на различных платформах, в том числе Linux. Наиболее простым и современным решением будут Google документы, так как открываются онлайн без скачивания прямо в браузере на любой платформе. Существуют российские качественные аналоги, например от Яндекса.
Будьте внимательны на мобильных устройствах, так как там используются упрощённый функционал даже в официальном приложении от Microsoft, поэтому для просмотра скачивайте PDF-версию. А если нужно редактировать файл, то используйте оригинальный файл.
Файлы такого типа обычно разбиты на страницы, а текст может быть форматированным (жирный, курсив, выбор шрифта, таблицы и т.п.), а также в него можно добавлять изображения. Формат идеально подходит для рефератов, докладов и РПЗ курсовых проектов, которые необходимо распечатать. Кстати перед печатью также сохраняйте файл в PDF, так как принтер может начудить со шрифтами.