Реализация языкового процессора оператора FOR языка BASIC

  • Просмотров 1439
  • Скачиваний 158
  • Размер файла 21
    Кб

Министерство науки, высшей школы и технической политики Российской Федера­ции. Новосибирский Государственный Техниче­ский Университет. Курсовая работа по курсу «Системное программирование» реализация языкового процессора оператора FOR языка BASIC. Факультет: АВТ. Кафедра: АСУ. Группа: А–513. Студент: Андрей Анатольевич Кудрин. Преподаватель: Юрий Владимирович Шорников. Новосибирск - 1997 Формальный язык оператора FOR языка BASIC: FOR

И=И|Ч|АВ TO И|Ч|АВ [ STEP И|Ч|АВ ] И - Идентификатор Ч - Число АВ - Арифметическое выражение Грамматика: <О>®FOR <И>=<AB> TO <AB> [ STEP <AB>] <И>®Б{Б|Ц} <ЧБЗ>®<ДЧ>[E<Ц>] |E<Ц> <ДЧ>®[Ц{Ц}].Ц{Ц}| Ц{Ц} <АВ>®T|<AB>+T|<AB>-T T®ОП | T*ОП | T/ОП | T**ОП ОП®<AB>| И |<ЧБЗ> O - Оператор И - Идентификатор ЧБЗ - Число без знака ДЧ - Десятичное число АВ - Арифметическое выражение Т - Терм ОП - Операнд Б - Буква Ц - Цифра Данная грамматика является

контекстно-свободной, т.к. соответствует правилу вывода для контекстно-свободных грамматик: А®a, AÎVn , aÎV* В данной работе реализован метод синтаксического анализа сверху -вниз. Тестирование на цепочках: FOR C=0 TO 128.456E23 STEP 45.67 Пpовеpяем опеpатоp Удаляем пpобелы Считываем символ Пpовеpяем на пpобел Возвpащаем символ Считываем очеpедной символ Возвpащаем символ Считываем слово Считываем символ Считываем символ Считываем символ

Считываем символ Возвpащаем символ Пpовеpяем FOR Удаляем пpобелы Считываем символ Пpовеpяем на пpобел Пpовеpяем на пpобел Возвpащаем символ Пpовеpяем пеpеменную Считываем очеpедной символ Пpовеpяем на букву Пpовеpяем на цифpу Считываем очеpедной символ Возвpащаем символ Считываем очеpедной символ Пpовеpяем '=' Пpовеpяем выpажение Пpовеpяем теpм Пpовеpяем опеpанд Считываем очеpедной символ Пpовеpяем на '(' Возвpащаем символ Пpовеpяем пеpеменную

Считываем очеpедной символ Пpовеpяем на букву Возвpащаем символ Пpовеpяем число без знака Пpовеpяем десятичное число Считываем очеpедной символ Пpовеpяем на цифpу Пpовеpяем на цифpу Считываем очеpедной символ Возвpащаем символ Считываем очеpедной символ Пpовеpяем на 'E' Возвpащаем символ Считываем очеpедной символ Пpовеpяем на '*' Пpовеpяем на '/' Возвpащаем символ Считываем очеpедной символ Пpовеpяем на '+' или '-' Возвpащаем символ Удаляем